国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:22:31
字體:
來源:轉載
供稿:網友

問題

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 大埔县| 谢通门县| 台江县| 彝良县| 彩票| 巴彦县| 吉林省| 蛟河市| 镇远县| 房产| 镇远县| 新绛县| 大石桥市| 昭通市| 封丘县| 昭通市| 惠东县| 赣榆县| 金寨县| 通辽市| 安国市| 抚宁县| 澎湖县| 弥勒县| 临汾市| 温泉县| 万年县| 九龙城区| 通江县| 安顺市| 延寿县| 赣州市| 吐鲁番市| 冷水江市| 方山县| 西盟| 双桥区| 曲麻莱县| 津市市| 铜陵市| 元谋县|