中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue計算屬性時v-for處理數組時遇到的一個bug問題

發布時間:2020-08-30 08:12:49 來源:腳本之家 閱讀:356 作者:CodingHot 欄目:web開發

問題

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問題,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望城县| 彭阳县| 溧阳市| 女性| 黎川县| 静安区| 高碑店市| 布尔津县| 保康县| 德州市| 临洮县| 中牟县| 秦皇岛市| 东兰县| 天峻县| 齐河县| 林芝县| 阿城市| 新兴县| 平塘县| 定州市| 新和县| 灵丘县| 岢岚县| 屯留县| 临江市| 扬州市| 晋中市| 德钦县| 永昌县| 保德县| 洛浦县| 望城县| 额尔古纳市| 顺昌县| 新平| 丰顺县| 秭归县| 靖州| 大渡口区| 当涂县|