小程序 表单验证

使用 WxValidate.js 插件来校验表单数据

常用实例方法 

名称返回类型描述
checkForm(e)boolean验证所有字段的规则,返回验证是否通过。
valid()boolean返回验证是否通过。
size()number返回错误信息的个数。
validationErrors()array返回所有错误信息。
addMethod(name, method, message)boolean添加自定义验证方法。

内置校验规则

序号规则描述
1required: true这是必填字段。
2email: true请输入有效的电子邮件地址。
3tel: true请输入11位的手机号码。
4url: true请输入有效的网址。
5date: true请输入有效的日期。
6dateISO: true请输入有效的日期(ISO),例如:2009-06-23,1998/01/22。
7number: true请输入有效的数字。
8digits: true只能输入数字。
9idcard: true请输入18位的有效身份证。
10equalTo: 'field'输入值必须和 field 相同。
11contains: 'ABC'输入值必须包含 ABC。
12minlength: 5最少要输入 5 个字符。
13maxlength: 10最多可以输入 10 个字符。
14rangelength: [5, 10]请输入长度在 5 到 10 之间的字符。
15min: 5请输入不小于 5 的数值。
16max: 10请输入不大于 10 的数值。
17range: [5, 10]请输入范围在 5 到 10 之间的数值。

 

根据 WxValidate.js 插件,定义 验证函数 initValidate 的规则及返回的信息,在 onLoad 生命周期中调用

使用 bindinput 、 bindblur 绑定事件和data-name传入对应的表单字段名 来实现单个输入框失焦的验证

initValidate() {
    //验证规则和提示信息
    let rulesAndMsg = {
      Name: {
        rules: {
          required: true
        },
        message: {
          required: '请输入姓名'
        }
      },
      IDCard: {
        rules: {
          required: true,
          idcard: true,
        },
        message: {
          required: '请输入身份证号',
          idcard: '请输入正确的身份证号码',
        }
      },
      Age: {
        rules: {
          required: true,
          rangeRom: [1, 120],
        },
        message: {
          required: '请输入年龄'
        }
      },
    }
    //实例化当前的验证规则和提示消息
    this.WxValidate = new WxValidate(rulesAndMsg);
    /**
             * 自定义验证规则传3个参数
             * name 是添加的方法的名字
             * method 是一个函数,value:元素的值,param是参数
             * message 是自定义的错误提示
             */
    this.WxValidate.addMethod('rangeRom', (value, param) => {
      return this.WxValidate.optional(value) || (value >= param[0] && value <= param[1])
    }, '年龄范围是: 1-120');
  },

提交时校验

if (!this.WxValidate.checkForm(this.data.form)) {
      //表单元素验证不通过,此处给出相应提示
      this.setData({
        errorList: this.WxValidate.errorList,
      })
      return false;
    }

更改了方法具体文件点此处详见

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黎轩栀海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值