vue本地没事放到服务器上无限循环,解决vue中的无限循环问题

项目中遇到了这样一个问题:每一种产品有对应的服务费,每一个商家有多种商品要单独计算每一家的服务费,最后汇总总的服务费用。我直接写了一个方法来计算出每个商家和总的服务费用并return出来。如果不看控制台的话运行是没问题的。但是控制台报了无限循环的错误。

e9e20c981adfbb2c6d57b368349be211.png

下面是错误代码

html:

b6336ccbb80f50da79913bbfa82d2e40.png

js:

e79d149326ce32462014a499df8b4309.png

这里会出现无限循环的原因是数据更新触发计算方法来更新视图,视图更新又反过来触发这个方法更新数据。所以尽量不要直接在绑定的数据上使用方法来绑定。找到问题后下面就是解决办法。

因为选中商品后就要重新计算价格。所以我将选中的商品添加到data里面

3435d01eb0fbdb4aabc88ce47b2583dc.png

然后通过侦听器监听totalBox的变化

9fb9bf29fe4b97d71973b73d5f64f2d9.png

当totalBox变化后在执行计算方法。这样就避免一直来回计算的问题

973228fe86444de445fb49fd1a27ce04.png

补充知识:vue 排序无限循环问题解决

在vue里对每个数组排序,会出现无限循环的问题,我认为的原因是:

vue动态监听data里数组的变化,数组刚一排序发生变化,vue立马重新执行排序导致无限循环。

解决问题:

1、将要排序的数组命名为全局变量,这样不受vue的监听

2、全局数组赋值vue里的数组时,不要使用=号,这样只是把全局数组的地址指向vue数组地址(用遍历vue数组,push进全局数组里)

代码片段 对数组对象属性进行排序(**************************为解决思路):

var sloveSortList = []; //解决vue中数组排序无限循环的问题 **************************

export default {

data() {

return {

showSectionList: [], //界面需要显示的断面,还没有进行排序

watch:{

//列表发生变化

showSectionList: function(){

//传递点位列表数据,给父级reallndex.vue页面

this.leftshowSection(this.showSectionList);

//把showSectionList数组赋值给sloveSortList,如果直接=,相当于引用地址,排序的时候vue监听showSectionList会出现无限循环。

sloveSortList = [];

for(var i=0; i < this.showSectionList.length; i++ ){

sloveSortList.push(this.showSectionList[i]); **************************

}

//把变化了的列表赋值到准备要排序的sortShowSectionData上

this.sortShowSectionList = this.sortShowSectionData() **************************

//赋值排好序的数组,为了搜索使用

this.beforeSearchList = this.sortShowSectionList;

//默认选中第一个断面传递给父组件

this.showSectionClick(0);

}

methods: {

//列表排序方法

sortShowSectionData:function(){

var factorNumber = this.nowFactor.factor_code+ 'Level';

if(this.nowFactor.factor_code == undefined || this.nowFactor.factor_code == 'NaN' || this.nowFactor.factor_code == null){

return

}

//对列表进行了排序

var searchList = sloveSortList.sort((a,b)=>{ **************************

var factorNumber = this.nowFactor.factor_code;

if(parseFloat(a[factorNumber]) > parseFloat(b[factorNumber])){

return -1;

} else if(parseFloat(a[factorNumber]) == parseFloat(b[factorNumber])){

return 0;

}else{

return 1;

}

});

return searchList;

},

以上这篇解决vue中的无限循环问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程圈。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值