vue elementUI实现自定义正则规则验证
项目场景:
常见的表单填写中都会遇到,比如新增信息,修改信息等,如下图
相信大家对上面的验证都非常熟悉了,不多哔哔 本篇文章主要 想写 验证规则自定义 相关的内容
验证是否是合法手机号(举例)
实现下图所示:
实现步骤:
step 1
准备好 reg表达式 , 百度即可 电话号码—— /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/
step 2
model 和 ref 最好一致
prop验证的phone_number 和 v-model 绑定的phone_number 的字段名也要一致 注意细节
<el-form :model="ruleForm" ref="ruleForm" :rules="rules"> <el-form-item label="xxx电话号码" prop="phone_number"> <el-input v-model="ruleForm.phone_number"></el-input> </el-form-item> </el-form> <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
step 3
data() { 饿了么文档上写的在这里定义一个 checkPhon_unm 回调 // 电话号码 验证 var checkPhon_unm = (rule, value, callback) => { if (value) { if (!/^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/.test(value)) { callback(new Error("请输入正确的电话号码!")); } else { callback(); } } else { callback(); } }; return { rules: { phone_number: [{ validator: checkPhon_unm, trigger: "blur" }], }, }; }, methods: { submitForm(formName) { this.$refs[formName].validate((valid) => { if (valid) { alert('submit!'); } else { console.log('error submit!!'); return false; } }); },
总结:
- 电话号码如此,其他都是一样的,举一反三而已
- 具体业务具体分析,有些是非必填项正则验证,有些相反
- 如果表单域需要自定义布局,不想使用饿了么自带的局部效果的话,最好把el-form包在最外层,不然也许会出现无法触发验证回调的可能
到此这篇关于vue elementUI实现自定义正则规则验证的文章就介绍到这了,更多相关vue elementUI 正则规则验证内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
在Vuex使用dispatch和commit来调用mutations的区别详解
今天小编就为大家分享一篇在Vuex使用dispatch和commit来调用mutations的区别详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-09-09关于在vscode使用webpack指令显示"因为在此系统中禁止运行脚本"问题(完美解决)
这篇文章主要介绍了解决在vscode使用webpack指令显示"因为在此系统中禁止运行脚本"问题,本文给大家分享完美解决方法,需要的朋友可以参考下2021-07-07Vue使用Composition API生成计算属性computed
这篇文章主要为大家详细介绍了Vue如何使用Composition API实现生成计算属性computed,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下2023-06-06
最新评论