Vue.js是采用數(shù)據(jù)劫持結(jié)合發(fā)布者-訂閱者模式得方式凭戴,通過Object.defineProperty()來劫持各個屬性的setter呜舒、getter,在數(shù)據(jù)變動時發(fā)布消息給訂閱者,觸發(fā)相應(yīng)監(jiān)聽的回調(diào)昵慌。
主要分為以下幾個步驟:
1.需要observe對數(shù)據(jù)對象進行遞歸遍歷,包括子屬性對象的屬性淮蜈,都加上setter和getter斋攀。這樣的話,給這個對象的某個值賦值礁芦,就會觸發(fā)setter蜻韭,那么就能監(jiān)聽到了數(shù)據(jù)變化
2.compile解析模板指令,將模板中的變量替換成數(shù)據(jù)柿扣,然后初始化渲染頁面視圖肖方,并將每個指令對應(yīng)的節(jié)點綁定更新函數(shù),添加監(jiān)聽數(shù)據(jù)的訂閱者未状,一旦數(shù)據(jù)變動俯画,收到通知更新視圖
3.Watcher訂閱者是Observe和Comoile之間通信的橋梁,主要做的事情是:
- 在自身實例化時往屬性訂閱器(dep)里面添加自己
- 自身必須有一個update()方法
- 待屬性變動dep.notice()通知時司草,能調(diào)用自身的update()方法艰垂,并觸發(fā)Compile中綁定的回調(diào),則功成身退
4.MVVM作為數(shù)據(jù)綁定的入口埋虹,整合Observe猜憎、Compile和Watcher三者。通過Observe來監(jiān)聽自己model數(shù)據(jù)變化搔课,通過Compile來解析模板指令胰柑,最終利用Watcher搭起Observe和Comoile之間的通信橋梁,達到數(shù)據(jù)變化 —>視圖更新爬泥;視圖交互變化(input) —>數(shù)據(jù)model變更柬讨。