這篇文章主要介紹了在做vue計算屬性,v-for處理數組時遇到的一個bug 問題,需要的朋友可以參考下
問題
bug: You may have an infinite update loop in a component render function 無限迴圈
1.需要處理的陣列(在** ssq **裡):
1 | bonus_code: ['01', '19', '25', '26', '27', '33', '10']
|
登入後複製
2.計算屬性computed:
1 2 3 4 5 6 | ssqRed: function () {
return this.ssq.bonus_code.splice(0, 6)
},
ssqBlue: function () {
return this.ssq.bonus_code.splice(6, 7)
}
|
登入後複製
3.v-for 程式碼:
1 2 | <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同時操作一個陣列
我已採納答案,將程式碼改成:
1 2 3 4 5 6 | ssqRed: function () {
return this.ssq.bonus_code.slice(0, 6)
},
ssqBlue: function () {
return this.ssq.bonus_code.slice(6, 7)
}
|
登入後複製
問題就在於自己沒搞清楚splice會對原數組造成改變。
在尋找解決方案時,朋友少暉教給我更好的解決方式,很感謝
即類別名稱判斷
#1.如果陣列大小已知,就做一個類別名稱判斷,索引大於多少展示藍色的類別名稱就行了;
2.處理後的html程式碼:
1 | <em v- for = "(item, index) in ssq.bonus_code" : class = "['tac','mr5','fl',index>5?'blue-ball':'red-ball']" >{{ item }}</em>
|
登入後複製
3.增加的程式碼:
1 | index>5?'blue-ball':'red-ball'
|
登入後複製
上面是我整理給大家的,希望今後會對大家有幫助。
相關文章:
關於vue2.0中datepicker使用方法
JavaScript調停者模式(詳細教學)
在jQuery中有關Dom元素使用方法?
在jQuery如何解決niceScroll滾動條錯位問題
詳細介紹js中有關promise的知識點
#在JS陣列中如何刪除某個元素
在Node.js中如何實作mysql事務自動回收連線
在vue.js中使用Nginx來解決跨域
以上是在vue中如何透過v-for處理數組的詳細內容。更多資訊請關注PHP中文網其他相關文章!