VUE2響應式原理使用Object.defineProperty缺點
引言
我們都知道vue2響應式原理是通過Object.defineProperty來實現(xiàn)的,通過劫持各屬性的setter和getter,監(jiān)聽數(shù)據(jù)的變化。
Object.defineProperty 的缺點
無法監(jiān)聽對象屬性的新增和刪除
let num = 3 const cat = { name: '大橘', sex: 'boy', age: 5 } Object.defineProperty(cat,'age',{ get() { console.log('get value') return num }, set(val) { console.log('set value', val) num = val } }) cat.age = 6 // 可以被監(jiān)聽到 cat.breed = '貍花貓' // 無法被監(jiān)聽到
解決方式新增屬性
this.$set(this.obj, 'a', 'abc')
刪除屬性
this.$delete(this.obj, 'a')
無法監(jiān)聽數(shù)組下標的變化,通過數(shù)組下標修改元素,無法實時響應?;谛阅芸紤]vue2放棄了Object.defineProperty這一特性,如果數(shù)組長度過大,比如1000條,性能代價和用戶體驗收益不成正比 參考
push() pop() shift() unshift() splice() sort() reverse()
只能劫持對象的屬性,所以我們需要對每個對象的所有屬性進行遍歷,然后需要深拷貝進行修改
而Proxy可以監(jiān)聽對象而非屬性,相比前者具有更好的性能
以上就是VUE2響應式原理使用Object.defineProperty缺點的詳細內(nèi)容,更多關于VUE2 Object.defineProperty缺點的資料請關注腳本之家其它相關文章!
相關文章
Element-UI介紹主題定制、自定義組件和插件擴展的代碼示例
本文介紹了使用Element-UI實現(xiàn)主題定制、自定義組件和擴展插件的方法和實用案例,在開發(fā)過程中,我們可以根據(jù)自己的需求,靈活選擇相關的技術手段,并不斷探索和嘗試,以提高開發(fā)效率和用戶體驗,感興趣的朋友跟隨小編一起看看吧2024-02-02