根据多选的选择,动态匹配/生成接口里面的数据

2024-06-18 13:36

本文主要是介绍根据多选的选择,动态匹配/生成接口里面的数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近遇到一个需求,一开始以为接口里面只会返回三个数据,就直接调取接口,页面写三个html结构接口数据放在那里了,后来接口又加了两条,因为前端这边没写结构,就没出来…
所以直接给他改为动态匹配的,不管后续后台这边添加多少条,都能保证数据出来
我的路径:之后看src\views\partner\partner\index.vue

页面为这样的:
在这里插入图片描述
根据选中的,去匹配下面的内容显示; 后台分了两个接口去区分: 一个接口显示上面的name部分
一个是下面的期数,期数接口传递当前id,上面有多少个name,就把他的相应id传递给第二个接口
第一个接口:
在这里插入图片描述
第二个接口:
在这里插入图片描述
根据他上面list里面有多少个id就会匹配当前id的全部期数

接下来直接上代码:

        <el-form-item required label="配置"><el-checkbox-groupv-model="checkList"class="checkbox-group"@change="updatePartnerProducts"><template v-for="(item, index) in labelsList"><el-checkboxv-if="item.code !== 'INTEGRAL_ENJOY_FIRST'":key="index":label="item.id">{{ item.name }}</el-checkbox></template></el-checkbox-group><divv-for="(item, index) in checkListOrder":key="index + 'check'"class="settings-container"><div v-if="item == 3"><el-form-item label="使用条件:" required class="settings-container"><el-radio-groupv-model="cashRadio"class="vert-radio-group"@change="handleCashRadioChange"><el-radio label="LIMIT">积分等级限制<span style="margin-left: 30px">等级达到:</span><el-selectv-model="level"style="width: 170px"clearableplaceholder="请选择"><el-optionv-for="item in levels":key="item.value":label="item.label":value="item.value"/></el-select></el-radio><el-radio label="DEDUCT">抵扣积分<span style="margin-left: 30px">需要抵扣积分:</span><el-inputv-model="integralNum"placeholder="请输入积分"style="width: 170px"autocomplete="off"/></el-radio><el-radio label="NON"></el-radio></el-radio-group></el-form-item></div><div><el-form-itemlabel-width="170px":label="labelNames[`checkListSetting${item}`] + '设置:'"requiredclass="settings-container"><el-checkbox-groupv-model="getDynamicCheckListSettings()[`checkListSetting${item}`]"@change="updatePartnerProducts"class="checkbox-grid"><el-checkboxv-for="n in dynamicAllTerms[`allTerms${item}`]"@change="handleCheckboxChange(item, n, $event)":key="n":label="n">{{ n }}</el-checkbox></el-checkbox-group></el-form-item></div></div></el-form-item>
data(){
return{checkList: [],//当前选中的iddynamicData: {},}
}
  created() {listProduct({ pageNum: 1, pageSize: 10, type: "CASH_LOAN" }).then((res) => {this.labelsList = res.rows;console.log("类型期数返回的res---", res);return Promise.all(this.labelsList.map((label) => listProductParams(label.id)));  //promise.all()等所有的请求执行完毕之后才会执行下面的}).then((products) => {console.log("products的值===", products);this.originProducts = cloneDeep(products);products.forEach((res, i) => {const termList = res.data.map((item) => item.term); //拿到他们的期数let list = res.data || [];if (list.length > 0) {let flist = this.labelsList.filter((item1) => item1.id == list[0].productId);this.$set(this.dynamicData, `checkListSetting${flist[0].id}`, termList); //选中this.$set(this.dynamicData,`allTerms${flist[0].id}`,Array.from(new Set(termList))); //循环期数}});});},
  computed: {后续一个排序问题,用这段解决checkListOrder() {let ids = this.labelsList.map((item) => item.id);return this.sortByOrder(this.checkList, ids);},// 根据id匹配namelabelNames() {let obj = this.labelsList.reduce((acc, item) => {acc[`checkListSetting${item.id}`] = item.name; // 初始化每个动态数组return acc;}, {});return obj;},//动态期数dynamicAllTerms() {let obj = this.checkList.reduce((acc, item) => {acc[`allTerms${item}`] = this.dynamicData[`allTerms${item}`]; return acc;}, {});return obj;},},
    getDynamicCheckListSettings() {let obj = this.checkList.reduce((acc, item) => {acc[`checkListSetting${item}`] = this.dynamicData[`checkListSetting${item}`];return acc;}, {});return obj;},handleCheckboxChange(item, n, event) {this.updateDynamicData(item, n, event);},updateDynamicData(item, n, value) {// 强制双向绑定if (value) {let list = cloneDeep(this.getDynamicCheckListSettings()[`checkListSetting${item}`]);list.push(n);this.$set(this.dynamicData, `checkListSetting${item}`, list);} else {let list = cloneDeep(this.getDynamicCheckListSettings()[`checkListSetting${item}`]);list = list.filter((item1) => item1 != n);this.$set(this.dynamicData, `checkListSetting${item}`, list);}},
//watch也要监听他的值,当选择发生变化时,获取最近的数据watch: {level: {handler() {this.updatePartnerProducts();},deep: true,},integralNum: {handler() {this.updatePartnerProducts();},deep: true,},checkList: {handler() {this.updatePartnerProducts();},deep: true,},cashRadio: {handler() {this.updatePartnerProducts();},deep: true,},},
    updatePartnerProducts() {// 清空partnerProductsthis.form.partnerProducts = [];this.checkList.forEach((item) => {const product = this.labelsList.find((item1) => item1.id == item);if (product) {let newObj = {productCode: product.code,// useCondition: this.cashRadio,productType: product.type,productId: product.id,conditionPeriods: this.getDynamicCheckListSettings()[`checkListSetting${item}`].join(","),};if (item == 3) {newObj = {...newObj,useCondition: this.cashRadio,};if (this.cashRadio === "LIMIT") {newObj = {...newObj,conditionVal: this.level,};} else if (this.cashRadio === "DEDUCT") {newObj = {...newObj,conditionVal: this.integralNum,};}}this.form.partnerProducts.push(newObj);}});},

编辑回显方法:

    initFormValues(partnerProducts) {this.checkList = partnerProducts.map((item) => item.productId || "").filter((e) => e);partnerProducts.forEach((item) => {this.$set(this.dynamicData,`checkListSetting${item.productId}`,item.conditionPeriods.split(",").map(Number));if (item.productId == 3) {this.cashRadio = item.useCondition;if (this.cashRadio === "LIMIT") this.level = item.conditionVal;if (this.cashRadio === "DEDUCT") {this.integralNum = item.conditionVal;}}});},

这篇关于根据多选的选择,动态匹配/生成接口里面的数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1072137

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre