动态校验列表数据方案

背景:当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
}
相关推荐
The_Ticker1 小时前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程
Elastic 中国社区官方博客1 小时前
Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
企鹅侠客1 小时前
ETCD调优
数据库·etcd
Json_181790144801 小时前
电商拍立淘按图搜索API接口系列,文档说明参考
前端·数据库
诸神黄昏EX1 小时前
Android 分区相关介绍
android
煎饼小狗1 小时前
Redis五大基本类型——Zset有序集合命令详解(命令用法详解+思维导图详解)
数据库·redis·缓存
永乐春秋2 小时前
WEB-通用漏洞&SQL注入&CTF&二次&堆叠&DNS带外
数据库·sql
打鱼又晒网2 小时前
【MySQL】数据库精细化讲解:内置函数知识穿透与深度学习解析
数据库·mysql
大白要努力!2 小时前
android 使用SQLiteOpenHelper 如何优化数据库的性能
android·数据库·oracle
Estar.Lee2 小时前
时间操作[取当前北京时间]免费API接口教程
android·网络·后端·网络协议·tcp/ip