iview表单校验上传图片成功后,提示文字不消失

       最近做的项目中有直播和课程后台管理模块,遇到一个bug,其中有个功能是上传直播图片和直播附件,而且都是必填项。用的框架是vue+iview,用Form表单验证,对必填项做校验。当不填写时点提交会出现红色提示文字,但是当图片上传成功后,提示文字并不会消失。尝试在自定义校验中进行判断如果图片变量有数据就不提示,但是不管用。最后发现在图片上传成功的组件里需要把数据返回到父页面,父页面接收到数据后调用 this.$refs.formValidate.validateField('livePictureUrl') 来重新校验表单,因为已经收到数据,所以校验通过,红色提示文字就会消失,所以这个bug是用自定义校验,记得自定义校验中要加type类型,加上成功后返回数据后加 this.$refs.formValidate.validateField('livePictureUrl')  这句话解决的,这只是个人见解,如有不对,请指教。

发现 this.$refs.formValidate.validateField('livePictureUrl') 超级好用,很多表单校验的地方都可以用到。

不上传图片,点击提交按钮的效果,会出现红色提示文字

但是当图片上传成功后,提示文字并不会消失。

做校验是通过iview表单验证的prop属性,具体校验查看iview官方文档

结构用Form表单校验结构:

 

 

data中定义变量,写校验规则

 

尝试在自定义校验中进行判断如果图片变量有数据就不提示,但是不管用

最后发现在图片上传成功的组件里需要把数据返回到父页面,父页面接收到数据后调用 this.$refs.formValidate.validateField('livePictureUrl') 来重新校验表单,因为已经收到数据,所以校验通过,红色提示文字就会消失

 

  • 8
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iview是一款基于Vue.js的UI组件库,提供了丰富的表格组件和表单校验功能。 在iview的表格组件中,可以使用表单校验功能来对每一行或特定列的数据进行校验。可以根据需要设置表格的rules属性来定义校验规则。 首先,我们需要定义校验规则,可以使用常见的校验规则例如required、max、min等,也可以定义自定义的校验规则。每个校验规则都可以附加一条错误信息。 在表格的columns属性中,可以通过scopedSlots可以定义每一列的渲染方式。在scopedSlots中,我们可以使用iview提供的FormItem组件来实现表单校验功能。 具体实现步骤如下: 1. 在表格的columns属性中,为需要校验的列设置scopedSlots属性,并在scopedSlots中使用FormItem组件包裹需要校验表单元素。 2. 在FormItem组件中,可以使用prop属性来指定表单元素对应的段名。同时,可以在FormItem组件中添加rules属性,指定对应的校验规则。 3. 在设置完校验规则后,可以通过v-model来与数据进行双向绑定。在校验不通过时,FormItem会自动显示错误信息。 通过以上步骤,我们就可以在iview的表格组件中实现表单校验功能。当用户在表格中输入数据时,会根据定义的校验规则进行实时校验,并在不通过时给出错误提示。 这样的表格内表单校验功能,可以帮助开发者更方便地对表格中的数据进行校验和验证,确保数据的准确性和完整性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值