免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

Vue雙向數據綁定的原理是什么-創新互聯

本篇文章給大家分享的是有關Vue雙向數據綁定的原理是什么,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創新互聯公司是一家集網站建設,囊謙企業網站建設,囊謙品牌網站建設,網站定制,囊謙網站建設報價,網絡營銷,網絡優化,囊謙網站推廣為一體的創新建站企業,幫助傳統企業提升企業形象加強企業競爭力。可充分滿足這一群體相比中小企業更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們為更多的企業打造出實用型網站。

MVVM

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

Vue雙向數據綁定的原理是什么

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

數據劫持

  vue.js 是采用數據劫持結合發布者-訂閱者模式的方式,通過Object.defineProperty()來劫持各個屬性的setter,getter,在數據變動時發布消息給訂閱者,觸發相應的監聽回調。

Object.defineProperty()

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

  Object.defineProperty(obj, prop, descriptor)

參數:

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

返回值:被傳遞給函數的對象。

MVVM 的數據雙向綁定步驟

  1、實現一個數據監聽器Observer,能夠對數據對象的所有屬性進行監聽,如有變動可拿到最新值并通知訂閱者

  2、實現一個指令解析器Compile,對每個元素節點的指令進行掃描和解析,根據指令模板替換數據,以及綁定相應的更新函數

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

  流程如下所示:

Vue雙向數據綁定的原理是什么

實現Observer

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

  這樣的話,給這個對象的某個值賦值,就會觸發setter,那么就能監聽到了數據變化。

實現Compile

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

Vue雙向數據綁定的原理是什么

實現Watcher

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

實現MVVM

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

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

以上就是Vue雙向數據綁定的原理是什么,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創新互聯-成都網站建設公司行業資訊頻道。

分享題目:Vue雙向數據綁定的原理是什么-創新互聯
分享路徑:http://m.newbst.com/article36/dcgspg.html

成都網站建設公司_創新互聯,為您提供網站維護定制開發搜索引擎優化微信小程序標簽優化移動網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網頁設計公司