這篇文章主要講解了如何實(shí)現(xiàn)Vue Object的變化偵測(cè),內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
數(shù)據(jù)觀察
Vue 中的對(duì)象變化偵測(cè)是通過Object.definePorperty實(shí)現(xiàn)的,但是Object.definePorperty的方式有缺陷,比如不能直接代理整個(gè)對(duì)象,每次都要循環(huán)遍歷對(duì)象的所有屬性;尤大大說之后會(huì)使用 ES6 中的Proxy 重寫這個(gè)部分。這篇博客介紹的是 Object.definePorperty 實(shí)現(xiàn)的對(duì)象偵測(cè)。
我們來看下面這段代碼,定義一個(gè) defineReactive 函數(shù),使用 Object.definePorperty 遍歷對(duì)象對(duì)象屬性的時(shí)候,設(shè)置 get 和 set;當(dāng)對(duì)象屬性被讀取的時(shí)候觸發(fā) get,對(duì)象屬性被設(shè)置的時(shí)候觸發(fā) set。這樣就完成了對(duì) data 的數(shù)據(jù)劫持,因?yàn)?Vue 的思想是響應(yīng)式的,我們還需要收集這些變化。
function defineReactive(data,key,val){ Object.definePorperty(data,key,{ enumerable: true, configurable: true, get:function(){ return val; } set :function (newVal){ if(val === newVal){return} val = newVal; } }) }