antd-vue/elementUi上传图片文件校验是否为空,解决不能直接使用 form-item validFeild校验、校验失败问题

先看实现效果:

 

 当我们使用ui框架校验上传图片或者文件时,代码一般会这么写:

<a-form-model
    ref="ruleForm"
    :model="form"
    :rules="rules"
>
    <a-form-model-item
        label="图片"
        prop="advertUrl"
        help="支持JPEG、PNG文件;上传尺寸为690*270px;大小不得超过4MB。"
    >
        <image-upload :value="form.advertUrl"/> //这是我二次封装的ui上传组件,如果直接使用ui框架的上传组件也可以
    </a-form-model-item>
</a-form-model>

value值或者文件值写成了form.xxx,这是正常的input的校验流程,当是上传文件的input时会发现校验失效了,上传了文件提示还在,如下所示:

 这是因为嵌套了组件或者嵌套了值,导致这个value值validFeild获取不到,视图没有更新,解决办法如下:

<a-form-model
    ref="ruleForm"
    :model="form"
    :rules="rules"
>
    <a-form-model-item
        label="图片"
        prop="advertUrl"
        help="支持JPEG、PNG文件;上传尺寸为690*270px;大小不得超过4MB。"
    >
        <image-upload :value="advertUrl" @change="uploadChange"/> //不要使用form包含,直接在data声明
    </a-form-model-item>
</a-form-model>

不要使用form对象包裹,直接在data声明,并且加一个获取文件的回调函数,使用$set赋值给form的校验文件值。

uploadChange(data) {
    this.$set(this.form, 'advertUrl', data[0])
},

这样就大功告成了,等于是上传组件的值和校验的值独立互不干扰,校验就正常了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值