背景:当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:false
this.validRulesList.warrantyManualUpload[0].required = (id.value === 'a')?true:false
if(id.value === 'a') {
this.validRulesList.warrantyManualDescr[0].required = true
const $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 = true
const $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
}