el-form 自定义校验规则

    //自定义校验规则
    var checkIdCard = (rule, value, cb) => {
      const regIdCard = /^[0-9A-Za-z]+$/;

      if (regIdCard.test(value)) {
        return cb();
      }

      cb(new Error('只能输入数字或字母'));
    };
    datacode: [
          { required: true, message: '请输入指标编码', trigger: 'blur' },
          { validator: checkIdCard, trigger: 'blur' },
        ],

在这里插入图片描述
------------------------------------------手动分割-------------------------------------------------------------------

在 Element UI 中的 el-form 组件中,可以通过自定义校验规则来进行表单验证。以下是一个示例,展示了如何在 el-form 中添加自定义的校验规则:

首先,在 Vue 的 data 中定义一个名为 rules 的对象,用于存储校验规则。校验规则以表单项的字段名作为 key,以数组的形式存储一个或多个校验规则。

data() {
  return {
    form: {
      name: '', // 表单项名称
      age: null, // 表单项年龄
    },
    rules: {
      name: [
        { required: true, message: '请输入姓名', trigger: 'blur' },
        { min: 2, max: 10, message: '姓名长度在2到10个字符之间', trigger: 'blur' }
      ],
      age: [
        { required: true, message: '请输入年龄', trigger: 'blur' },
        { type: 'number', message: '年龄必须为数字', trigger: 'blur' },
        { validator: this.checkAge, trigger: 'blur' }
      ]
    }
  };
},

在 methods 中定义一个名为 checkAge 的校验函数,该函数接收三个参数:rule、value 和 callback。其中,rule 是当前校验的规则,value 是当前校验的值,callback 是回调函数,在校验完成后使用它来返回校验结果。

methods: {
  checkAge(rule, value, callback) {
    if (value < 0 || value > 150) {
      callback(new Error('年龄必须在0到150之间'));
    } else {
      callback();
    }
  }
},
 checkNum(rule, value, callback) {
      const positiveRegex = /^(?!0+(\.0+)?$)\d{1,13}(\.\d{1,4})?$/;
      if (!positiveRegex.test(value)) {
        callback(new Error("资金必须大于0,并且最多保留4位小数"));
      } else {
        callback();
      }
    },

在 el-form-item 中使用 :rules 属性将对应的校验规则应用到表单项上。


<el-form :model="form" :rules="rules"></el-form>
  <el-form-item label="姓名" prop="name">
    <el-input v-model="form.name"></el-input>
  </el-form-item>
  <el-form-item label="年龄" prop="age">
    <el-input-number v-model="form.age"></el-input-number>
  </el-form-item>
</el-form>

通过以上步骤,你可以在 el-form 组件中使用自定义的校验规则进行表单验证。校验规则可以包括内置的验证规则(如 required、min、max 等),也可以自定义 validator 规则来执行更复杂的校验逻辑。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
el-form 提供了很多内置的表单校验规则,但是有时候我们需要自定义校验规则来满足业务需求。在 el-form自定义校验可以通过 rules 属性来实现。具体步骤如下: 1. 在 el-form 中设置 rules 属性,并定义一个对象来存储自定义校验规则,例如: ``` <el-form :model="form" :rules="rules"> ... </el-form> data() { return { form: { ... }, rules: { name: [ { required: true, message: '请输入姓名', trigger: 'blur' }, { validator: this.checkName, trigger: 'blur' } ] } } }, ``` 2. 在 rules 对象中定义校验规则,可以使用内置的校验规则,也可以自定义 validator 规则。例如: ``` checkName(rule, value, callback) { const reg = /^[\u4e00-\u9fa5]{2,4}$/; // 中文姓名的正则表达式 if (value && !reg.test(value)) { callback(new Error('请输入正确的中文姓名')); } else { callback(); } } ``` 在自定义 validator 规则中,第一个参数 rule 是当前校验规则的配置对象,第二个参数 value 是当前表单项的值,第三个参数 callback 是回调函数,用于返回校验结果。如果校验不通过,需要调用 callback(new Error('错误提示')) 方法,如果校验通过,则直接调用 callback() 方法即可。 3. 在 el-form-item 中设置 prop 属性来指定当前表单项的 model 字段,并设置 :rules 属性来指定当前表单项的校验规则。例如: ``` <el-form-item label="姓名" prop="name"> <el-input v-model="form.name"></el-input> </el-form-item> ``` 通过以上步骤即可实现 el-form 中的自定义校验
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值