uniapp 真机调式自定义表单校验失效
uniapp 表单校验真机失效
·
validateFunction 自定义校验规则
uni-forms
的 rules
基础规则有时候不能满足项目的所有使用场景,这时候可以使用 validateFunction
来自定义校验规则
validateFunction
方法返回四个参数 validateFunction:function(rule,value,data,callback{}
,当然返回参数名开发者可以自定义:
- rule : 当前校验字段在 rules 中所对应的校验规则
- value : 当前校验字段的值
- data : 所有校验字段的字段和值的对象
- callback : 校验完成时的回调,一般无需执行callback,返回true(校验通过)或者false(校验失败)即可 ,如果需要显示不同的
errMessage
,如果校验不通过需要执行 callback('提示错误信息'),如果校验通过,执行callback()即可
- 需要注意,如果需要使用
validateFunction
自定义校验规则,则不能采用uni-forms
的rules
属性来配置校验规则,这时候需要通过ref
,在onReady
生命周期调用组件的setRules
方法绑定验证规则 - 无法通过props传递变量,是因为微信小程序会过滤掉对象中的方法,导致自定义验证规则无效。
- 如果使用了
validateFunction
且required
为false
的情况,表现为不填写内容不校验,有内容才校验,所以内容为空时validateFunction
不会执行 - 但是!!!
validateFunction和popup弹出层一起使用,对popup弹出层内的表单进行校验,在小程序运行的是好的,但是在app端校验不生效,并且onReady里面自定义校验报错
,主要原因就是DOM没有渲染出来,获取不到form表单实例,设置了定时器延后设置校验规则,通过this.$nextTick和uni.$nextTick都没有解决这个问题,是因为uni-popup组件弹出层用了v-if,v-if 是直接将dom元素添加或者删除,将v-if改成v-show即可
更多推荐
已为社区贡献1条内容
所有评论(0)