vue计算属性时v-for处理数组时遇到bug分析

  • 更新时间:2020-04-20 08:44:26
  • 编辑:谢刚毅
给大家整理了vue相关的编程文章,网友庾经赋根据主题投稿了本篇教程内容,涉及到vue计算属性、vue、v-for、vue计算属性时v-for处理数组时遇到的一个bug问题相关内容,已被386网友关注,下面的电子资料对本篇知识点有更加详尽的解释。
  • Vue.js项目实战 / 141 MB 推荐度:
  • 《Vue.js前端开发基础与项目实战》项目源码 / 741 MB 推荐度:
  • Vue.js devtools / 461 KB 推荐度:
  • 《Vue.js+Node.js开发实战:从入门到项目上线》配书资源 / 10.25 MB 推荐度:
  • Vue.js前端开发:快速入门与专业应用 / 3.6KB MB 推荐度:
  • vue计算属性时v-for处理数组时遇到的一个bug问题

    问题

    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.bonus_code.splice(0, 6)
    },
    ssqBlue: function() {
    return this.ssq.bonus_code.splice(6, 7)
    }

    3.v-for 代码:

    <em class="red-ball tac mr5 fl" v-for="(item, index) in ssqRed">{{ item }}</em>
    <em class="blue-ball tac mr5 fl" v-for="(item, index) in ssqBlue">{{ item }}</em>

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

    解答

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

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

    ssqRed: function() {
     return this.ssq.bonus_code.slice(0, 6)
    },
    ssqBlue: function() {
     return this.ssq.bonus_code.slice(6, 7)
    }

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

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

    即类名判断

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

    2.处理后的 html代码:

    <em v-for="(item, index) in ssq.bonus_code" :class="['tac','mr5','fl',index>5?'blue-ball':'red-ball']" >{{ item }}</em>

    3.增加的代码:

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

    总结

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

    vue相关教程

    用户留言