Vue2中無法檢測到數(shù)組變動的原因及解決
由于JavaScript 的限制,Vue 不能檢測以下數(shù)組的變動:
- 當利用索引直接設置一個數(shù)組項時,例如:vm.items[indexOfItem] = newValue
- 當修改數(shù)組的長度時,例如:vm.items.length = newLength
var vm = new Vue({ data: { items: ['a', 'b', 'c'] } }) vm.items[1] = 'x' // 不是響應性的 vm.items.length = 2 // 不是響應性的
解決方法
手動添加監(jiān)聽 // Vue.set Vue.set(vm.items, indexOfItem, newValue) vm.$set(vm.items, indexOfItem, newValue) 使用數(shù)組的變異方法,因為vue對數(shù)組的變異方法實現(xiàn)了響應式 // Array.prototype.splice vm.items.splice(indexOfItem, 1, newValue)
為什么Vue2.0中監(jiān)聽不到兩種數(shù)組的變化?
官方文檔中對于這兩點都是簡要的概括為“由于JavaScript的限制”無法實現(xiàn),而Object.defineProperty是實現(xiàn)檢測數(shù)據(jù)改變的方案,那這個限制是指Object.defineProperty嗎?
其實原因并不是因為Object.defineProperty()存在漏洞,而是出于性能問題的考慮。 Object.defineProperty 在數(shù)組中的表現(xiàn)和在對象中的表現(xiàn)是一致的,數(shù)組的索引就可以看做是對象中的 key 。
- 通過索引訪問或設置對應元素的值時,可以觸發(fā) getter 和 setter 方法
- 通過 push 或 unshift 會增加索引,對于新增加的屬性,需要再手動初始化才能被 observe 。
- 通過 pop 或 shift 刪除元素,會刪除并更新索引,也會觸發(fā) setter 和 getter 方法。
所以, Object.defineProperty 是有監(jiān)控數(shù)組下標變化的能力的,只是vue2.x放棄了這個特性。
源碼分析
Object.property是可以檢測到通過索引改變數(shù)組的操作的,而Vue沒有實現(xiàn)。那我們看看源碼:
Vue3.0
Vue3.0中則用proxy代替了Object.defineProperty()解決了其存在的問題
以上就是Vue2中無法檢測到數(shù)組變動的原因及解決的詳細內(nèi)容,更多關于Vue2 數(shù)組變動的資料請關注腳本之家其它相關文章!
相關文章
vue異步組件與組件懶加載問題(import不能導入變量字符串路徑)
這篇文章主要介紹了vue異步組件與組件懶加載問題(import不能導入變量字符串路徑),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04vue異步axios獲取的數(shù)據(jù)渲染到頁面的方法
今天小編就為大家分享一篇vue異步axios獲取的數(shù)據(jù)渲染到頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08Vue + Scss 動態(tài)切換主題顏色實現(xiàn)換膚的示例代碼
這篇文章主要介紹了Vue + Scss 動態(tài)切換主題顏色實現(xiàn)換膚的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04Vue render函數(shù)實戰(zhàn)之實現(xiàn)tabs選項卡組件
這篇文章主要介紹了Vue render函數(shù)實戰(zhàn)之實現(xiàn)tabs選項卡組件的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04vue3+ts重復參數(shù)提取成方法多處調(diào)用以及字段無值時不傳字段給后端問題
在進行API開發(fā)時,優(yōu)化參數(shù)傳遞是一個重要的考量,傳統(tǒng)方法中,即使參數(shù)值為空,也會被包含在請求中發(fā)送給后端,這可能會導致不必要的數(shù)據(jù)處理,而優(yōu)化后的方法則只會傳遞那些實際有值的字段,從而提高數(shù)據(jù)傳輸?shù)挠行院秃蠖颂幚淼男?/div> 2024-10-10vue2.0 資源文件assets和static的區(qū)別詳解
這篇文章主要介紹了vue2.0 資源文件assets和static的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04最新評論