很多的前端框架都支持?jǐn)?shù)據(jù)雙向綁定了,最近正好在看雙向綁定的實(shí)現(xiàn),就用Javascript寫了幾個簡單的例子。
幾個例子中嘗試使用了下面的方式實(shí)現(xiàn)雙向綁定:
發(fā)布/訂閱模式
屬性劫持
臟數(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”屬性的控件):
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26