Vue+elementUI的动态表单的校验(根据条件动态切换校验格式)

前言

开发过程当中遇到了一个需求,根据用户选择的联系方式,动态改变输入框的检验条件,
而且整个表单是能够增长的git

在线访问:动态表单校验
github(欢迎star):https://github.com/Mrblackant...github

动态表单

思考几个问题

1.整个表单是可新增的,因此要遍历生成;
2.联系方式(手机/座机)的切换,是要切换后边不一样类型输入框仍是只改变校验规则(本篇是动态改变校验规则)ui

实现

1.elementui的form表单实现校验的时候要给当前el-form-item加上prop属性,
由于咱们是遍历生成的表单,那咱们的写法就要写成:
重点在prop属性this

<template v-for="(k,index) in formData.lists">
 <el-form-item
    :ref="index+'concatValue'"
    :prop="'lists.' + index +'.concatValue'"
    :rules="k.rules">
    <el-input v-model="k.concatValue"></el-input>
 </el-form-item>
</template>

2.由于我选择了根据类型动态修改校验规则,而不是切换不一样类型的输入框,
注意看下上文代码中的ref和rules,当类型切换时,对应的:rules=k.rules对应的规则也会进行修改,:ref属性是为了切换联系方式类型时,先清除掉以前的提示。spa

看下不一样类型的校验规则,统一的先放到一个地方:.net

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代码里重复写code

const baseRule = [
  { required: true, message: '请填写联系方式', trigger: 'blur' }
]

而后等切换校验类型的时候,把必填校验baseRule链接起来:component

// 给表单加上新的校验
      this.formData.lists[index].rules = [this.inputRules[data]].concat(baseRule)

动态表单校验、动态校验规则这块没有太难的地方,就是有时候会被绕晕,因此拿出来记录一下,你们有更好的方案欢迎指出orm

相关文章
相关标签/搜索