色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Vue雙向數(shù)據(jù)綁定(MVVM)的原理

瀏覽:76日期:2022-11-17 13:19:25

MVVM

MVVM 是Model-View-ViewModel 的縮寫,它是一種基于前端開發(fā)的架構(gòu)模式,其核心是提供對View 和 ViewModel 的雙向數(shù)據(jù)綁定,這使得ViewModel 的狀態(tài)改變可以自動傳遞給 View,即所謂的數(shù)據(jù)雙向綁定。

Vue雙向數(shù)據(jù)綁定(MVVM)的原理

Vue.js 是一個提供了 MVVM 風格的雙向數(shù)據(jù)綁定的 Javascript 庫,專注于View 層。它的核心是 MVVM 中的 VM,也就是 ViewModel。 ViewModel負責連接 View 和 Model,保證視圖和數(shù)據(jù)的一致性,這種輕量級的架構(gòu)讓前端開發(fā)更加高效、便捷。

數(shù)據(jù)劫持

vue.js 是采用數(shù)據(jù)劫持結(jié)合發(fā)布者-訂閱者模式的方式,通過Object.defineProperty()來劫持各個屬性的setter,getter,在數(shù)據(jù)變動時發(fā)布消息給訂閱者,觸發(fā)相應(yīng)的監(jiān)聽回調(diào)。

Object.defineProperty()

Object.defineProperty() 方法會直接在一個對象上定義一個新屬性,或者修改一個對象的現(xiàn)有屬性, 并返回這個對象。

Object.defineProperty(obj, prop, descriptor)

參數(shù):

obj--要在其上定義屬性的對象。 prop--要定義或修改的屬性的名稱。 descriptor--將被定義或修改的屬性描述符。

返回值:被傳遞給函數(shù)的對象。

MVVM 的數(shù)據(jù)雙向綁定步驟

1、實現(xiàn)一個數(shù)據(jù)監(jiān)聽器Observer,能夠?qū)?shù)據(jù)對象的所有屬性進行監(jiān)聽,如有變動可拿到最新值并通知訂閱者

2、實現(xiàn)一個指令解析器Compile,對每個元素節(jié)點的指令進行掃描和解析,根據(jù)指令模板替換數(shù)據(jù),以及綁定相應(yīng)的更新函數(shù)

3、實現(xiàn)一個Watcher,作為連接Observer和Compile的橋梁,能夠訂閱并收到每個屬性變動的通知,執(zhí)行指令綁定的相應(yīng)回調(diào)函數(shù),從而更新視圖4、MVVM入口函數(shù),整合以上三者。

流程如下所示:

Vue雙向數(shù)據(jù)綁定(MVVM)的原理

實現(xiàn)Observer

我們知道可以利用Obeject.defineProperty()來監(jiān)聽屬性變動,那么將需要observe的數(shù)據(jù)對象進行遞歸遍歷,包括子屬性對象的屬性,都加上 setter和getter。

這樣的話,給這個對象的某個值賦值,就會觸發(fā)setter,那么就能監(jiān)聽到了數(shù)據(jù)變化。

實現(xiàn)Compile

compile主要做的事情是解析模板指令,將模板中的變量替換成數(shù)據(jù),然后初始化渲染頁面視圖,并將每個指令對應(yīng)的節(jié)點綁定更新函數(shù),添加監(jiān)聽數(shù)據(jù)的訂閱者,一旦數(shù)據(jù)有變動,收到通知,更新視圖,如圖所示:

Vue雙向數(shù)據(jù)綁定(MVVM)的原理

實現(xiàn)Watcher

Watcher訂閱者作為Observer和Compile之間通信的橋梁,主要做的事情是:1、在自身實例化時往屬性訂閱器(dep)里面添加自己2、自身必須有一個update()方法3、待屬性變動dep.notice()通知時,能調(diào)用自身的update()方法,并觸發(fā)Compile中綁定的回調(diào),則功成身退。

實現(xiàn)MVVM

MVVM作為數(shù)據(jù)綁定的入口,整合Observer、Compile和Watcher三者,通過Observer來監(jiān)聽自己的model數(shù)據(jù)變化,通過Compile來解析編譯模板指令,最終利用Watcher搭起Observer和Compile之間的通信橋梁。

達到數(shù)據(jù)變化 -> 視圖更新;視圖交互變化(input) -> 數(shù)據(jù)model變更的雙向綁定效果。

以上就是Vue雙向數(shù)據(jù)綁定(MVVM)的原理的詳細內(nèi)容,更多關(guān)于Vue 雙向數(shù)據(jù)綁定(MVVM)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 黄色影院在线观看视频 | 国产免费午夜a无码v视频 | 国产在线观看免费视频软件 | 三级全黄a| 国产一线视频在线观看高清 | 中文字幕日韩精品有码视频 | 一级毛片真人不卡免费播 | 57pao强力打造手机版 | 手机看片久久国产免费不卡 | 一区二区三区免费观看 | 在线成人a毛片免费播放 | 日韩专区欧美 | 精品久久久久亚洲 | 亚洲第一中文字幕 | 久久国产国内精品对话对白 | 99久久国产综合精品五月天 | 亚洲一级毛片 | 国产欧美一区二区三区沐欲 | 好湿好紧好痛a级是免费视频 | 欧美色老头oldvideos | 一级视频网站 | 国内91视频 | 深夜国产 | 一区二区三区网站在线免费线观看 | 亚洲男人的天堂在线观看 | 欧美日韩黄色 | 精品国产一区二区三区四区vr | 波多野结衣一区二区在线 | 男人女人做性全程视视频 | 久久久香蕉 | 2020国产微拍精品一区二区 | 国产在线视频h | 欧美一级高清毛片aaa | 欧美成人tv在线观看免费 | aa日本| 欧美成人毛片 | 毛片网站免费在线观看 | 真人毛片视频 | 在线观看欧美亚洲日本专区 | 国产亚洲精| 一级毛片免费观看不卡的 |