vue 循环列表双向绑定后改变数据造成赋值死循环的解决方案

本文介绍了在Vue中处理循环列表并进行双向绑定时遇到的数据更新死循环问题。通过分析需求,即产品配置渠道折扣价格,探讨了如何避免因直接操作对象导致的无限循环更新。文章提到了使用`Object.assign`来深拷贝对象,从而中断可能的循环引用,确保正确地更新和展示数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先说需求

产品绑定多个渠道后, 每个渠道需要配置下级所有等级和分类组合的折扣价格

参考设计图稿

先不谈等级和分类的组合

我们先思考渠道数据的显示

在基于上面多选输出后, 需要对比数据库数据是否存在, 如果存在则填充输入框的值,如果不存在则填充空数据

于是有这样的代码

 let listItem=this.formData.channelList.find(v=>
                                v.classifyId===channelItem.classifyCation[j].id &&
                                v.rankId===channelItem.rank[k].id &&
                                v.channelId===channelId
                            );
                            if(!listItem){
                                listItem={
                                    channelId:channelId,
                                    classifyId:channelItem.classifyCation[j].id,
                                    rankId:channelItem.rank[k].id,
              
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值