vue自定义rules,对input表单输入框校验重复值

对input表单输入框检验重复值,如对如下图参数名进行校验重复值 

el-form-item添加属性:rules="rules.paramname"

1.写一个rules

rules: {
       
        paramname: [
            {  required: true, validator: this.validateTitle, trigger: 'blur' }
        ],
        
      },

2.Method里面添加如下方法

rule:指的是表单中rules属性

value:指的表单输入框中输入的值

callback:回调函数(再次调用校验函数)

//参数名称校验
    validateTitle (rule, value, callback) {

      if (typeof value === 'undefined'||value.length == 0) {
        // callback(new Error('请输入参数'))
        this.$message({
                    message:'【参数名】不可以为空',
                    type: 'warning'
                })
      } else {
        try {
            let x = 0;
            for(let i = 0; i < this.myform.userList.length; i++ ){
              if (this.myform.userList[i].name == value){
                  x=x+1;
              }
              if(x == 2){
                throw new Error("type-check-error");
              }
            }
            callback()
            return true
        } catch (e) {
            if (e.message == "type-check-error") {
                this.$message({
                    message:'【参数名:'+value+'】已存在',
                    type: 'warning'
                })
                return false
            }
        }

      }
    },

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值