背景:当select 选择A 的时候是必填,选B的时候是非必填
那么我们需要监听 selec 变化时候对 列表的 :edit-rules=“validRulesList” 进行重新赋值必填校验的true, (跟对列表内上传文件,对列表文件进行赋值名字一样道理,通过获取对应的校验值,或者列表对应的字段进行赋值)
Rules列表
validRules: {
warrantyManualDescr:[{ required: false, message: this.$t('test') }],
warrantyManualUpload:[{ required: false, message: this.$t('test') }],}
通过获取对应的校验值进行赋值,注意在改变的时候,会因为列表是数组,最下面的值的改变会影响到其他数据的必填值,所以需要else 对整个表进行查询处理,查到就 return 节约时间
async ptypeChangeEvent (row, id) {this.validRulesList.warrantyManualDescr[0].required = (id.value === 'a')?true:falsethis.validRulesList.warrantyManualUpload[0].required = (id.value === 'a')?true:falseif(id.value === 'a') {this.validRulesList.warrantyManualDescr[0].required = trueconst $table = this.$refs.sublistTableData;const errMap = await $table.validate(true)}else {for(let i=0; i<this.sublistTableData.length; i++) {let e = this.sublistTableData[i]if(e.warrantyManualNorm == 'UNSWD') {this.validRulesList.warrantyManualDescr[0].required = trueconst $table = this.$refs.sublistTableData;const errMap = await $table.validate(row.row)return}}}
},
提交 submit 按钮的时候操作
对存在 必填字段的值查到 就 return 防止循环到下一个不是必填的字段(注意我们是在列表中进行判断,循环不做 return 会 继续到最后,出现 校验弹框 又被覆盖的情况)
通过对是否存在要校验的列表进行收集,对以后的计算进行拦截
/*字表校验操作*/
const $table = this.$refs.sublistTableData;
let arr = []
for(let i=0; i<this.sublistTableData.length; i++) {let e = this.sublistTableData[i]if(e.warrantyManualNorm == 'a') {const errMap = await $table.validate(e)if(errMap) {arr.push(errMap)return}}
}
if(arr.length>0) {return false
}