亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

万山特区| 榆林市| 浦北县| 鲜城| 互助| 梅河口市| 遂平县| 分宜县| 杭锦后旗| 江孜县| 磐石市| 蒙山县| 扎赉特旗| 新田县| 海原县| 固镇县| 汉中市| 杨浦区| 平果县| 工布江达县| 青田县| 得荣县| 马尔康县| 浦县| 宁都县| 江永县| 嘉兴市| 张家港市| 讷河市| 呼图壁县| 三都| 景洪市| 巫山县| 佛山市| 都昌县| 稷山县| 冕宁县| 绩溪县| 图木舒克市| 子洲县| 海城市|