vue計(jì)算屬性時(shí)v-for處理數(shù)組時(shí)遇到的一個(gè)bug問題
問題
bug: You may have an infinite update loop in a component render function 無限循環(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上提問,地址: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)
}
問題就在于自己沒搞清楚 splice會(huì)對原數(shù)組造成改變。
在尋找解決方案時(shí),朋友少暉教給我一種更好的解決方式,很感謝
即類名判斷
1.如果數(shù)組大小已知,就做一個(gè)類名判斷,索引大于多少展示藍(lán)色的類名就行了;
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問題,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
Vue版本vue2.9.6升級(jí)到vue3.0的詳細(xì)步驟
vue版本升級(jí)相信大家應(yīng)該都遇到過,下面這篇文章主要給大家介紹了關(guān)于Vue版本vue2.9.6升級(jí)到vue3.0的詳細(xì)步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
vue3+elementPlus二次封裝表單的實(shí)現(xiàn)代碼
最近使用Vue3+ElementPlus開發(fā)項(xiàng)目,從整體上構(gòu)思組件的封裝。能寫成組件的內(nèi)容都進(jìn)行封裝,方便多個(gè)地方使用,這篇文章給大家介紹了vue3+elementPlus二次封裝表單的實(shí)現(xiàn),并通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
vue如何解決echarts升級(jí)后本地?zé)o法啟動(dòng)的問題
這篇文章主要介紹了vue如何解決echarts升級(jí)后本地?zé)o法啟動(dòng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
VUE+Element UI實(shí)現(xiàn)簡單的表格行內(nèi)編輯效果的示例的代碼
這篇文章主要介紹了VUE+Element UI實(shí)現(xiàn)簡單的表格行內(nèi)編輯效果的示例的代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10

