el-form关于上传图片校验功能解决方法浅谈(非常简单)

相对于输入框和选择框校验而言,图片上传校验有些不大好用,网上找了一些解决方法也是比较复杂。

解决思路:

1.在需要校验的原有属性中增加一个图片是否存在的标识

2.在上传图片所属el-form-item中添加一个v-show=false的输入框,该输入框绑定的值便是图片标识

3.对于图片的校验字段更改为对输入框标识的校验:如存在为"1",不存在为""

4.(重点)更改标识的方法不能用直接赋值,要用this.$set,图片上传成功即为"1",图片删除要判断是否还有其余图片

上例子:

<el-form
 :rules="rules"
 :model="formCon"
 ref="formCon1"
>
    <el-form-item ref="commodityImage" prop="imageBs" label="商品图片:">
        <el-input v-show="false" v-model="formCon.imageBs" show-word-limit type="text">
                </el-input>
    </el-form-item>
</el-form>
data() {
      formCon: { imageBs:''},
      rules: {
          imageBs: [ 
              { required: true, message: '请选择商品图片', trigger: 'change'}
          ],
      },
}

上传图片成功的方法:on-success中增加

this.$set(this.formCon,'imageBs',"1");

图片删除的方法中增加

if(this.commodityImage.length > 0){ // commodityImage存放图片的数组
        this.$set(this.formCon,'imageBs',"1");
      } else{
        this.$set(this.formCon,'imageBs',"");
      }

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 `el-form` 存在多个 `el-form-item` 需要遍历的情况下,可以使用 `v-for` 指令来动态生成 `el-form-item`,并且对其进行校验。 下面是一个示例代码: ```html <template> <el-form :model="form" :rules="rules" ref="myForm" label-width="100px"> <el-form-item v-for="(item, index) in formItems" :key="index" :label="item.label" :prop="item.prop"> <el-input v-model="form[item.prop]"></el-input> </el-form-item> <el-button type="primary" @click="validateForm">提交</el-button> </el-form> </template> <script> export default { data() { return { form: {}, formItems: [ { label: '字段1', prop: 'field1' }, { label: '字段2', prop: 'field2' }, //... ], rules: { // 校验规则 // 可根据实际需求进行定义 field1: [ { required: true, message: '字段1不能为空', trigger: 'blur' }, //... ], field2: [ { required: true, message: '字段2不能为空', trigger: 'blur' }, //... ], //... } }; }, methods: { validateForm() { this.$refs.myForm.validate((valid) => { if (valid) { // 表单校验通过,可以继续处理提交逻辑 // ... } else { // 表单校验不通过,进行错误处理 // ... } }); } } }; </script> ``` 在上述示例,通过 `v-for` 指令遍历 `formItems` 数组生成多个 `el-form-item`,并且在 `el-form-item` 通过 `:prop` 绑定对应的字段名。同时,在 `el-form` 组件上设置了 `:rules` 属性,用于指定表单项的校验规则。 在点击提交按钮时,通过调用 `validateForm` 方法来触发表单校验。该方法内部使用 `$refs` 引用获取到表单组件,并调用其 `validate` 方法进行校验校验结果通过回调函数返回,可以根据校验结果进行后续处理。 请注意,校验规则和错误处理需要根据实际需求进行定义和实现。以上示例仅供参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值