您现在的位置是:网站首页> 编程资料编程资料
element表单使用校验之校验失效问题详解_vue.js_
2023-05-24
305人已围观
简介 element表单使用校验之校验失效问题详解_vue.js_
首先是html必须正确,直接看代码示例:
第一种可能的错误: 字段错误
其中的每个 el-form-item 标签中,都有一个 prop ,其中的值是我们 rules 对象中的 某个 属性。
然后我们 v-model 绑定的值也必须是 这个 属性
比如我们的字段是 userName,我们的prop还是name时,校验失效
再来看js中的代码:
form: { name: undefined, sex: undefined, age: undefined }, rules: { name: [ { required: true, message: "用户名称不能为空", trigger: "blur" }, { min: 2, max: 20, message: '用户名称长度必须介于 2 和 20 之间', trigger: 'blur' } ], sex: [ { required: true, message: "性别不能为空", trigger: "blur" } ], age: [ { required: true, message: "年龄不能为空", trigger: "blur" }, { pattern: /^([0-9]|[1-9]\d|[1-9]\d\d)$/, message: '年龄介于 0-999 之间', trigger: 'blur' } ] }第二种:触发校验错误
rules 中 每个校验对象 都有一项 trigger 是检验触发的方式
对 el-input 输入框的验证,trigger的值选blur,即失去焦点时进行验证。
下拉框 el-select、日期选择器 el-date-picker、复选框 el-checkbox、单选框 el-radio验证时,trigger的值选择change,即当值发生变化时就进行验证。
没有任何输入的时候,不会触发 change , 但一定会触发 blur 事件
注:如果使用了其他的组件(非ele组件等),组件中没有 v-model 等等情况时,值改变时需要我们手动去触发校验
| 方法名 | 说明 | 参数 |
| validateField | 对部分表单字段进行校验的方法 | Function(props: array | string, callback: Function(errorMessage: string)) |
this.$refs.表单ref名称.validateField(校验字段);
validator
最后提一下自定义校验,用于一些校验一些复杂的值
validator的参数有:(rule, value, callback),前三个比较重要。
- rule:指向该条规则对象。
- value:新的值,用于参与运算、对比。
- callback:执行回调,使用方法是:callback('...');。
- 如果不传参:表示验证通过,一般不必专门强调。
- 如果传入值:字符串会作为错误提示,但是显示优先级低于外层的message。比如callback('内层错误提示');跟message: '外层错误提示'同时存在,则会提示:外层错误提示。
直接看代码
data(){ const name = (rule, value, callback) => { console.log(rule) console.log(value) console.log(callback) if (this.oldName === value) { callback(new Error("新名字不能和旧名字一致")); } else { callback(); } }; return { rules: { name: [ { required: true, trigger: "blur", message: "请再次输入新名字" }, { required: true, validator: name, trigger: "blur" } ] } }
更多的参数和核心代码 可以查看 ele 实现校验使用的 async-validator
总结
到此这篇关于element表单使用校验之校验失效问题的文章就介绍到这了,更多相关element表单校验失效内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- react-dnd API拖拽工具详细用法示例_React_
- React DnD如何处理拖拽详解_React_
- uniapp获取底部安全距离以及状态栏高度等_javascript技巧_
- uniapp封装axios的详细过程(大可不必那么麻烦)_javascript技巧_
- 无UI 组件Headless框架逻辑原理用法示例详解_JavaScript_
- vue实现移动端适方案的完整步骤_vue.js_
- vue3使用element-plus中el-table组件报错关键字'emitsOptions'与'insertBefore'分析_vue.js_
- Vue3中使用vant的踩坑实战日记_vue.js_
- Vue 运行高德地图官方样例,设置class无效的解决_vue.js_
- React常见跨窗口通信方式实例详解_React_
