赞
踩
前言
开发过程中遇到了一个需求,根据用户选择的联系方式,动态改变输入框的检验条件,并且整个表单是可以增加的
在线访问:动态表单校验
github(欢迎star): https://github.com/Mrblackant. ..
思考几个问题
1.整个表单是可新增的,所以要遍历生成;
2.联系方式(手机/座机)的切换,是要切换后边不同类型输入框还是只改变校验规则(本篇是动态改变校验规则)
实现
1.elementui的form表单实现校验的时候要给当前el-form-item加上prop属性,因为我们是遍历生成的表单,那我们的写法就要写成:
重点在prop属性
2.因为我选择了根据类型动态修改校验规则,而不是切换不同类型的输入框,
注意看下上文代码中的ref和rules,当类型切换时,对应的:rules=k.rules对应的规则也会进行修改,:ref属性是为了切换联系方式类型时,先清除掉之前的提示。
看下不同类型的校验规则,统一的先放到一个地方: inputRules: {//设置好需要的校验规则 telephone: { pattern: /^1[3-9]\d{9}$/, message: '手机号格式错误', trigger: 'blur' }, phone: { pattern: /^\d{10,12}$/, message: '座机号格式错误', trigger: 'blur' }, QQ: { pattern: /^[1-9][0-9]{4,14}$/, message: 'QQ格式错误', trigger: 'blur' }, mail: { pattern: /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/, message: '邮箱格式错误', trigger: 'blur' } },
3.如果你的联系方式的值都是必填的,可以先写一个统一的必填校验,省的在步骤2代码里重复写 const baseRule = [ { required: true, message: '请填写联系方式', trigger: 'blur' } ]
然后等切换校验类型的时候,把必填校验baseRule连接起来: // 给表单加上新的校验 this.formData.lists[index].rules = [this.inputRules[data]].concat(baseRule)
动态表单校验、动态校验规则这块没有太难的地方,就是有时候会被绕晕,所以拿出来记录一下,大家有更好的方案欢迎指出
总结
以上所述是小编给大家介绍的基于Vue+elementUI实现动态表单的校验功能(根据条件动态切换校验格式),希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的! 您可能感兴趣的文章:Vue+ElementUI实现表单动态渲染、可视化配置的方法Vue ElementUI之Form表单验证遇到的问题Vue ElementUi同时校验多个表单(巧用new promise)vue elementui form表单验证的实现使用Vue实现图片上传的三种方式vue-quill-editor实现图片上传功能vue.js 图片上传并预览及图片更换功能的实现代码Vue2.0 实现移动端图片上传功能基于vue-upload-component封装一个图片上传组件的示例vue+node实现图片上传及预览的示例方法vue+elementUI实现表单和图片上传及验证功能示例
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。