主页 > 电脑硬件  > 

关于项目中遇到的一些form表单校验

1.model 属性绑定 form 数据对象 const formModel = ref({ username: '', password: '', repassword: '' }) <el-form :model="formModel" > 2.v-model 绑定 form 数据对象的子属性 <el-input v-model="formModel.username" :prefix-icon="User" placeholder="请输入用户名" ></el-input> ... (其他两个也要绑定) 3.rules配置校验规则 <el-form :rules="rules" > // 整个表单的校验规则 // 1.非空校验 required: true message消息提示,trigger触发校验的时机 blur change // 2.长度校验 min: xx, max: xx // 3.正则校验 pattern: 正则规则 \S 非空字符 // 4.自定义校验 => 自己写逻辑校验(校验函数) // validator: (rules, value, callback) // (1)rule 当前校验规则的相关信息 // (2)value 所校验的表单元素目前的表单值 // (3)callback 无论成功还是失败,都需要 callback 回调 // -callback() 校验成功 // -callback(new Error(错误信息)) const rules = { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, { min: 5, max: 10, message: '用户名必须是 5-10 位 的字符', trigger: 'blur' } ], password: [ { required: true, message: '请输入密码', trigger: 'blur' }, { pattern: /^\S{6,15}$/, message: '密码必须是6-15位的非空字符', trigger: 'blur' } ], repassword: [ { required: true, message: '请输入密码', trigger: 'blur' }, { pattern: /^\S{6,15}$/, message: '密码必须是6-15位的非空字符', trigger: 'blur' }, { validator: (rules, value, callback) => { // 判断 value 和 当前 form 中收集的 password 是否一致 if (value !== formModel.value.password) { callback(new Error('两次输入的密码不一致')) } else { callback() //就算校验成功,也需要callback } }, trigger: 'blur' } ] } 4.prop 绑定校验规则 <el-form-item prop="username"> <el-input v-model="formModel.username" :prefix-icon="User" placeholder="请输入用户名" ></el-input> </el-form-item> ... (其他两个也要绑定prop)

标签:

关于项目中遇到的一些form表单校验由讯客互联电脑硬件栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“关于项目中遇到的一些form表单校验