<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

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

          2021-10-9    前端達人

          vue.js 是采用數據劫持結合發布者-訂閱者模式的方式,通過 Object.de?neProperty()來劫持各個屬性的 setter,getter,在數據變動時發布消息給訂閱者,觸發相應的監聽回調。 具體步驟: 第一步:需要

          observe 的數據對象進行遞歸遍歷,包括子屬性對象的屬性,都加上 setter 和 getter,這樣的 話,給這個對象的某個值賦值,就會觸發 setter,那么就能監聽到了數據變化。 第二步:compile 解析模板指令,將模板中的變量替換成數據,然后初始化渲染頁面視圖,并將每個指令對 應的節點綁定更新函數, 添加監聽數據的訂閱者,一旦數據有變動,收到通知,更新視圖。 第三步:Watcher 訂閱者是

          Observer 和 Compile 之間通信的橋梁,主要做的事情是:

          1、在自身實例化時往屬 性訂閱器(dep)里面添加自己

          2、自身必須有一個 update()方法

          3、待屬性變動 dep.notice()通知時,能調用自身的update()方法,并觸發 Compile 中綁定的回調,則功成身退。 第四步:MVVM 作為數據綁定的入口, 整合 Observer、Compile 和 Watcher 三者,通過 Observer 來監聽自己 的 model 數據變化,通過Compile 來解析編譯模板指令,最終利用 Watcher 搭起 Observer 和 Compile 之間的通信 橋梁,達到數據變化 -> 視圖更新;視圖交互變化(input)-> 數據 model 變更的雙向綁定效果。









          藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請掃碼藍小助,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系。

          分享此文一切功德,皆悉回向給文章原作者及眾讀者.

          轉自:csdn
          免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。

          藍藍設計www.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://www.sdgs6788.com

          存檔

          久久最近最新中文字幕大全| 久久综合给合久久狠狠狠97色 | 久久亚洲春色中文字幕久久久| 久久青青草原精品国产软件| 久久亚洲精品无码播放| 免费无码国产欧美久久18| 久久久久久久亚洲Av无码| 99久久精品国产综合一区| 欧洲国产伦久久久久久久| 久久九九久精品国产免费直播| 精品国际久久久久999波多野| 2020最新久久久视精品爱| 欧美日韩精品久久久久| 2020最新久久久视精品爱| 亚洲中文久久精品无码| 国产亚洲精午夜久久久久久| 亚洲AV日韩精品久久久久久| 久久精品国产99国产精品| 蜜臀av性久久久久蜜臀aⅴ| 亚洲午夜精品久久久久久浪潮| 久久99中文字幕久久| 少妇人妻88久久中文字幕| 狠狠色丁香婷婷综合久久来来去 | 久久九九久精品国产| 亚洲乱码精品久久久久..| 国内精品久久久久久久coent | 久久99国产精品久久99小说| 久久综合丁香激情久久| 伊人久久综合精品无码AV专区| 久久久久亚洲AV成人网人人网站| 久久66热人妻偷产精品9| 久久婷婷五月综合成人D啪 | 久久国产成人午夜aⅴ影院| 久久偷看各类wc女厕嘘嘘| 狠狠色狠狠色综合久久| 国产香蕉久久精品综合网| 亚洲国产成人久久精品99| 久久国产午夜精品一区二区三区| 久久精品这里热有精品| 伊人丁香狠狠色综合久久| 精品久久久久久国产|