element-ui的表单验证如何清除校验提示语

问题场景:

最近在进行项目开发的时候,遇到了这样的一个问题:
对表单域中的数据进行校验的时候,其中有一项比较特殊,不是简单的输入框,下拉框这些表单元素,而是自己写的一个el-table的选择弹窗,我对它的校验如如下:

protocolId: [
   { required: true, message: '请选择解析协议', trigger: 'blur'},
],

这样可以实现校验功能,但是会存在一个问题,如果触发的了校验条件(提交按钮),提示了错误信息,后续即使重新选择了数据,错误信息依旧会存在,因为没有再次点击提交按钮,触发校验。这样用户体验就不是太好。
初次校验
选择数据以后的样式


解决方案:

1. 对字段进行单独校验

点击保存按钮触发校验,一般都是校验所有的字段,element-ui中的form表单组件还提供了校验一个字段的函数,使用方式如下:

 this.$refs.addForm.validateField('protocolId', (valid) => {
 	//valid返回的是规则集中写的错误提示信息,如果满足条件,返回的就是空
     if(!valid){
         return 
     }
 })

上面这段代码可以放在确认数据选择的函数中执行,这样就对这一项特殊的内容再次进行了校验,如果符合检验规则,错误提示就是消失了。

2. 直接清除表单域下该字段的提示信息

 this.$refs.addForm.clearValidate();

这个方法就是直接清除错误信息,不做任何判断,个人不是太推荐使用

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值