校验对象

  1. New方法用于创建一个新的校验对象。
  2. Assoc用于关联数据校验,具体请查看后续章节介绍。
  3. Bail方法用于设定只要后续的多个校验中有一个规则校验失败则停止校验立即返回错误结果。
  4. Ci方法用于设置需要比较数值的规则时,不区分字段的大小写。
  5. Run方法对给定规则和信息的数据进行校验操作。
  6. I18n方法用于设置当前校验对象的I18N国际化组件。默认情况下,校验组件使用的是框架全局默认的i18n组件对象。
  7. Data方法用于传递需要联合校验的数据集合,往往传递的是map类型或者struct类型。
  8. Rules方法用于传递当前链式操作校验的自定义校验规则,往往使用[]string类型或者map类型。
  9. Messages方法用于传递当前链式操作校验的自定义错误提示信息,往往使用map类型传递,具体看后续代码示例。

使用示例

  1. err error
  2. ctx = gctx.New()
  3. )
  4. err = g.Validator().
  5. Data(16).
  6. Messages("未成年人不允许注册哟").
  7. Run(ctx)
  8. fmt.Println(err.Error())
  9. // Output:
  10. // 未成年人不允许注册哟
  1. type User struct {
  2. Name string `v:"required#请输入用户姓名"`
  3. Type int `v:"required#请选择用户类型"`
  4. }
  5. var (
  6. err error
  7. ctx = gctx.New()
  8. user = User{}
  9. data = g.Map{
  10. }
  11. if err = gconv.Scan(data, &user); err != nil {
  12. panic(err)
  13. }
  14. err = g.Validator().Assoc(data).Data(user).Run(ctx)
  15. if err != nil {
  16. fmt.Println(err.(gvalid.Error).Items())
  17. }
  18. // Output:
  19. // [map[Type:map[required:请选择用户类型]]]
  1. {
  2. "passport": {
  3. "length": "账号长度应当在6到16之间",
  4. "required": "账号不能为空"
  5. },
  6. "password": {
  7. "same": "两次密码输入不相等"
  8. }