很多的前端框架都支持?jǐn)?shù)據(jù)雙向綁定了,最近正好在看雙向綁定的實(shí)現(xiàn),就用Javascript寫了幾個簡單的例子。

幾個例子中嘗試使用了下面的方式實(shí)現(xiàn)雙向綁定:

  1. 發(fā)布/訂閱模式

  2. 屬性劫持

  3. 臟數(shù)據(jù)檢測

發(fā)布/訂閱模式

實(shí)現(xiàn)數(shù)據(jù)雙向綁定最直接的方式就是使用PubSub模式:

  • 當(dāng)model發(fā)生改變的時候,觸發(fā)Model change事件,然后通過響應(yīng)的事件處理函數(shù)更新界面

  • 當(dāng)界面更新的時候,觸發(fā)UI change事件, 然后通過相應(yīng)的事件處理函數(shù)更新Model,以及綁定在Model上的其他界面控件

根據(jù)這個思路,可以定義'ui-update-event'和'model-update-event'兩個事件,然后針對Model和UI分別進(jìn)行這兩個事件訂閱和發(fā)布。

UI更新

對于所有支持雙向綁定的頁面控件,當(dāng)控件的“值”發(fā)生改變的時候,就觸發(fā)'ui-update-event',然后通過事件處理函數(shù)更新Model,以及綁定在Model上的其他界面控件

處理控件“值”的改變,發(fā)布“ui-update-event”事件,(這里只處理包含“t-binding”屬性的控件):

        		

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運(yùn),軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式