vue计算属性时v

网友投稿 293 2023-02-25


vue计算属性时v

问题

bug: You may have an infinite update loop in a component render function 无限循环

1.需要处理的数组(在 ** ssq **里):

bonus_code: ['01', '19', '25', '26', '27', '33', '10']

2.计算属性 computed:

ssqRed: function() {

return this.ssq.bonushttp://_code.splice(0, 6)

},

ssqBlue: function() {

return this.ssq.bonus_code.splice(6, 7)

}

3.v-for 代码:

{{ item }}

{{ item }}

4.最终结果我想把数组前6个数渲染成红色球,最后一个(也就是第7个)渲染成蓝色。

解答

我已经在 SegmentFault上提问,地址:vue计算属性computed同时操作一个数组

我已采纳答案,将代码改成:

ssqRed: function() {

rhttp://eturn this.ssq.bonus_code.slice(0, 6)

},

ssqBlue: function() {

return this.ssq.bonus_code.slice(6, 7)

}

问题就在于自己没搞清楚 splice会对原数组造成改变。

在寻找解决方案时,朋友少晖教给我一种更好的解决方式,很感谢

即类名判断

1.如果数组大小已知,就做一个类名判断,索引大于多少展示蓝色的类名就行了;

2.处理后的 html代码:

{{ item }}

3.增加的代码:

index>5?'blue-ball':'red-ball'

总结

以上所述是给大家介绍的vue计算属性时v-for处理数组时遇到的一个bug问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,会及时回复大家的!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:网页百度地图接口测试用例(前端百度地图api)
下一篇:在Java Web项目中添加定时任务的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~