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

首頁 > 編程 > JavaScript > 正文

Vue infinite update loop的問題解決

2019-11-19 11:43:39
字體:
來源:轉載
供稿:網友

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

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]

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新乐市| 高唐县| 广西| 区。| 彩票| 随州市| 呈贡县| 农安县| 沁阳市| 巴塘县| 延长县| 资溪县| 郯城县| 富锦市| 辽阳市| 湖州市| 安塞县| 洛扎县| 阳山县| 喀喇沁旗| 东乡| 宝丰县| 淮北市| 靖远县| 祁门县| 通化市| 巴里| 东光县| 凤翔县| 上林县| 海伦市| 湟源县| 玛曲县| 云霄县| 大同市| 武汉市| 太湖县| 石林| 文化| 绥化市| 大关县|