之前關(guān)于 Vue 數(shù)據(jù)綁定原理的一點(diǎn)分析,最近需要回顧,就順便發(fā)到隨筆上了
在之前實(shí)現(xiàn)一個(gè)自己的Mvvm中,用setter
來觀測(cè)model
,將界面上所有的viewModel
綁定到model
上。 當(dāng)model
改變,更新所有的viewModel
,將新值渲染到界面上 。同時(shí)監(jiān)聽界面上通過v-model
綁定的所有input
,并通過addEventListener
事件將新值更新到model
上,以此來完成雙向綁定 。
但是那段程序除了用來理解defineProperty
,其它一文不值。
這里我將解決表達(dá)式依賴這個(gè)問題,vue 模板的編譯我會(huì)在下一節(jié)介紹 。
為數(shù)據(jù)定義 getter & setter
class Observer { constructor(data) { this._data = data; this.walk(this._data); } walk(data) { Object.keys(data).forEach((key) => { this.defineRective(data, key, data[key]) }) }; defineRective(vm, key, value) { var self = this; if (value && typeof value === "object") { this.walk(value); } Object.defineProperty(vm, key, { get: function() { return value; }, set: function(newVal) { if (value != newVal) { if (newVal && typeof newVal === "object") { self.walk(newVal); } value = newVal; } } }) } } module.exports = Observer;
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前題目:詳解Vue事件驅(qū)動(dòng)和依賴追蹤-創(chuàng)新互聯(lián)
網(wǎng)站鏈接:http://chinadenli.net/article4/deehoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站收錄、標(biāo)簽優(yōu)化、建站公司、網(wǎng)站策劃、動(dòng)態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容