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

溫馨提示×

溫馨提示×

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

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

Vue infinite update loop的問題解決

發布時間:2020-10-13 08:58:15 來源:腳本之家 閱讀:427 作者:Mr_zhang 欄目:web開發

一個尤大大曾回復過的問題

vue warn : You may have an infinite update loop in a component render function

最近再寫一個數組渲染時,源數據是拿到的數組經過排序后的數組,正常運行卻出現爆紅:

報紅代碼:

computed: {
 ...mapState({
  fromNames (state) {
  let fromNames = state.quote.fromNames;
  return fromNames.sort((a, b) => b.isBind - a.isBind);;
  },
 }),
 },

然后...

Vue infinite update loop的問題解決

然后百思不得解,最終找到源頭:

Vue infinite update loop的問題解決

你的確導致了一個無限循環, 因為array.sort()改變了數組自身,導致了過濾器又一次被觸發。確保在副本上對數組排序:
return value.slice().sort(...)

解決方案:

computed: {
 ...mapState({
  fromNames (state) {
  let fromNames = state.quote.fromNames;
  return fromNames.slice().sort((a, b) => b.isBind - a.isBind);
  },
 }),
 },

數組方法 array.slice()用法

arr.slice([begin[, end]])

slice() 方法會淺復制(shallow copy)數組的一部分到一個新的數組,并返回這個新數組。

begin 起始位置 如果未定義,就默認0;如果大于數組長度,返回空數組;如果是負數,則從末尾算起;

end 結束位置(不包含該位置元素)如果省略了,就默認到末尾;如果大于數組長度,就取數組長度;如果是負數,則從末尾算起。

技巧:處理類數組對象

slice() 可以用于把一個類數組對象轉化為一個新數組

例如:

function list() {
 return Array.prototype.slice.call(arguments);
}

var list1 = list(1, 2, 3); // [1, 2, 3]

也可以使用.call綁定在函數的Function.prototype(也可以被簡化為[].slice.call(arguments)

var unboundSlice = Array.prototype.slice;
var slice = Function.prototype.call.bind(unboundSlice);

function list() {
 return slice(arguments);
}

var list1 = list(1, 2, 3); // [1, 2, 3]

或者

[].slice.call({ 0: 0, 1 : 2, 2: 4, length: 4 })
//[0, 2, 4, empty]

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

交城县| 莱芜市| 聊城市| 稷山县| 江北区| 马山县| 莱州市| 普陀区| 民勤县| 荆州市| 铜梁县| 满洲里市| 三台县| 闸北区| 宜昌市| 集安市| 长垣县| 中超| 金坛市| 广东省| 炉霍县| 阿克苏市| 当涂县| 万盛区| 韶关市| 民县| 乐亭县| 吕梁市| 龙里县| 普定县| 民权县| 广丰县| 宝清县| 曲松县| 惠东县| 长治市| 康马县| 牙克石市| 菏泽市| 新龙县| 碌曲县|