溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

vue計(jì)算屬性時(shí)v-for處理數(shù)組時(shí)遇到的一個(gè)bug問(wèn)題

發(fā)布時(shí)間:2020-08-30 08:12:49 來(lái)源:腳本之家 閱讀:356 作者:CodingHot 欄目:web開(kāi)發(fā)

問(wèn)題

bug: You may have an infinite update loop in a component render function 無(wú)限循環(huán)

1.需要處理的數(shù)組(在 ** ssq **里):

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

2.計(jì)算屬性 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.最終結(jié)果我想把數(shù)組前6個(gè)數(shù)渲染成紅色球,最后一個(gè)(也就是第7個(gè))渲染成藍(lán)色。

解答

我已經(jīng)在 SegmentFault上提問(wèn),地址:vue計(jì)算屬性computed同時(shí)操作一個(gè)數(shù)組

我已采納答案,將代碼改成:

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

問(wèn)題就在于自己沒(méi)搞清楚 splice會(huì)對(duì)原數(shù)組造成改變。

在尋找解決方案時(shí),朋友少暉教給我一種更好的解決方式,很感謝

即類(lèi)名判斷

1.如果數(shù)組大小已知,就做一個(gè)類(lèi)名判斷,索引大于多少展示藍(lán)色的類(lèi)名就行了;

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'

總結(jié)

以上所述是小編給大家介紹的vue計(jì)算屬性時(shí)v-for處理數(shù)組時(shí)遇到的一個(gè)bug問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI