Vue infinite update loop的問題解決

這篇文章主要介紹了Vue "...infinite update loop..."的問題解決,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

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);;
  },
 }),
 },

然後...

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

你的確導致了一個無限循環, 因爲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]

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章