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
    评论
Vue3中,如果点击输入框以外的地方没有触发失焦事件,而只有再次点击并聚焦输入框,再点击输入框以外的地方,失焦事件才能触发,这可能是因为在模板中使用了条件渲染生成的输入框,并没有通过聚焦事件focus触发。 要解决这个问题,你可以在输入框上添加ref属性,并通过该ref属性在Vue组件中获取输入框的DOM元素。例如,在模板中给输入框添加ref属性:`<input class="ring-2" ref="nameInput" v-else v-model="name" type="text" @blur="submitEditName" @keyup.enter="submitEditName" />` 然后,在Vue组件的方法中,可以通过`this.$refs.nameInput`来获取到输入框的DOM元素,并在需要的时候进行操作。比如,你可以在失焦事件blur中调用提交编辑的方法submitEditName,代码如下: ```javascript methods: { submitEditName() { // 处理提交编辑的逻辑 } } ``` 这样,无论是点击输入框以外的地方还是按下回车键,都会触发失焦事件,从而调用提交编辑的方法。这样就可以实现输入框失焦的功能了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【Vue实践】VueInput框失焦事件无效问题解决](https://blog.csdn.net/baidu_36511315/article/details/118516072)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值