vue计算属性时v-for处理数组时遇到的一个bug问题
问题
bug:Youmayhaveaninfiniteupdateloopinacomponentrenderfunction无限循环
1.需要处理的数组(在**ssq**里):
bonus_code:['01','19','25','26','27','33','10']
2.计算属性computed:
ssqRed:function(){ returnthis.ssq.bonus_code.splice(0,6) }, ssqBlue:function(){ returnthis.ssq.bonus_code.splice(6,7) }
3.v-for代码:
{{item}} {{item}}
4.最终结果我想把数组前6个数渲染成红色球,最后一个(也就是第7个)渲染成蓝色。
解答
我已经在SegmentFault上提问,地址:vue计算属性computed同时操作一个数组
我已采纳答案,将代码改成:
ssqRed:function(){ returnthis.ssq.bonus_code.slice(0,6) }, ssqBlue:function(){ returnthis.ssq.bonus_code.slice(6,7) }
问题就在于自己没搞清楚splice会对原数组造成改变。
在寻找解决方案时,朋友少晖教给我一种更好的解决方式,很感谢
即类名判断
1.如果数组大小已知,就做一个类名判断,索引大于多少展示蓝色的类名就行了;
2.处理后的html代码:
5?'blue-ball':'red-ball']">{{item}}
3.增加的代码:
index>5?'blue-ball':'red-ball'
总结
以上所述是小编给大家介绍的vue计算属性时v-for处理数组时遇到的一个bug问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!