這篇文章主要講解了如何實(shí)現(xiàn)Vue Object的變化偵測(cè),內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
在弓長(zhǎng)嶺等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都做網(wǎng)站、成都網(wǎng)站制作 網(wǎng)站設(shè)計(jì)制作按需網(wǎng)站建設(shè),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營(yíng)銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè),弓長(zhǎng)嶺網(wǎng)站建設(shè)費(fèi)用合理。數(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; } }) }