首頁 >web前端 >js教程 >vue計算屬性時v-for處理陣列時遇到bug問題詳解

vue計算屬性時v-for處理陣列時遇到bug問題詳解

小云云
小云云原創
2018-01-24 10:47:002190瀏覽

本文主要介紹了在做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="[&#39;tac&#39;,&#39;mr5&#39;,&#39;fl&#39;,index>5?'blue-ball':'red-ball']" >{{ item }}</em>

3.增加的程式碼:

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

相關推薦:

v-for實作產生table並為table加上序號方法

實例講解vue v-for 資料處理

vue元件中v for指令介紹及使用v-for出現警告問題解析

以上是vue計算屬性時v-for處理陣列時遇到bug問題詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn