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

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

相关文章

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可