element-ui 表单验证注意事项

1、表单验证注意

其中的每个 el-form-item 标签中,都有一个 prop ,其中的值是我们 rules 对象中的 某个 属性。

然后我们 v-model 绑定的值也必须是 这个 属性

比如我们的字段是 userName,我们的prop还是name时,校验失效

<el-form-item label="名称" prop="name"> <el-input v-model="form.userName"></el-input> </el-form-item>

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' } ] }

2、触发校验错误

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的参数有:(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" } ] } }

相关推荐
qq_12498707535 分钟前
基于Javaweb的《战舰世界》游戏百科信息系统(源码+论文+部署+安装)
java·vue.js·人工智能·spring boot·游戏·毕业设计·计算机毕业设计
铅笔侠_小龙虾7 分钟前
浅谈 Vue & React & Flutter 框架
vue.js·flutter·react.js
前端摸鱼匠14 分钟前
Vue 3 的ref在响应式对象中:介绍ref在reactive对象中的自动解包
前端·javascript·vue.js·前端框架·ecmascript
Polaris_YJH19 分钟前
使用Vue3+Vite+Pinia+elementUI搭建初级企业级项目
前端·javascript·elementui·vue
菜鸟una19 分钟前
【微信小程序+Taro 3+NutUI 3】input (nut-input) 、 textarea (nut-texteare)类型使用避坑
前端·vue.js·微信小程序·小程序·taro
日光倾21 分钟前
【Vue.js 入门笔记】 状态管理器Vuex
vue.js·笔记·flutter
Jiaberrr22 分钟前
小程序setData性能优化指南:避开坑点,让页面丝滑如飞
前端·javascript·vue.js·性能优化·小程序
~牧马~11 小时前
【记录63】electron打包vue项目之踩坑
vue.js·electron·electron与node兼容
踏过山河,踏过海11 小时前
【用ui文件做个简单工具的开发,为什么修改完ui后,程序重新编译运行后,GUI界面还是不变呢?】
qt·ui
计算机学姐12 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法