中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue的底層原理是什么

發布時間:2022-02-14 14:34:24 來源:億速云 閱讀:238 作者:小新 欄目:開發技術

這篇文章主要介紹Vue的底層原理是什么,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

Vue的底層原理是什么

Observer (數據劫持)

核心是通過Obeject.defineProperty()來監聽數據的變動,這個函數內部可以定義setter和getter。
每當數據發生變化,就會觸發setter()。這時候 Observer 就要通過 Dep 通知 Watcher 訂閱者。

Dep (發布者)

有 addWatcher() 和 notify() 兩個方法,(收集 Watcher 依賴,并通知依賴變更)

Dep 保存多個 atcher,當 Dep 發現 Observer 有更新時,Dep 會調用 notify() 方法去通知 Watcher 進行更新

Watcher (訂閱者)

有一個 update() 方法,(訂閱 Dep ,接收數據變更)

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

1. 在自身實例化時往 Dep 中添加自己;

2. 待屬性變動接收到 Dep.notice() 通知時,能調用自身的 update() 方法,并觸發Compile中綁定的回調。

Compile

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

Vue的底層原理是什么

總結歸納:

vue 作為一種MVVM模式的框架, 其數據綁定的底層原理為:數據劫持 + 發布訂閱者模式

其中主要有這么四種“角色”

  • Observer 

  • Dep數據收集

  • Watcer訂閱者

  • Compiler 模板編譯器。

Observer 主要負責 數據劫持, 核心是通過Obeject.defineProperty()來監聽數據的變動,這個函數內部可以定義setter和getter。每當數據發生變化,就會觸發setter()。這時候 Observer 就要通知給Dep 說有數據發生了變化。

發布訂閱模式主要是通過 Dep 和 Watcher 來完成。

Dep 中存放著 Watcher 實例化時存放的所有依賴,是個數據集,當 Dep 收到來自 Observer 的數據變化通知時,會調用 notice() 方法把發生變化的依賴告訴 Watcher。

Watcher 是訂閱者,是連接 Observer 和 Compile 之間通信的橋梁,當它收到來自 Dep 的數據變化通知后,會調用自身的 update() 方法,并觸發Compile中綁定的回調。

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

源碼目錄結構

├─ .circleci                   // 包含CircleCI持續集成/持續部署工具的配置文件
├─ .github                   // 項目相關的說明文檔,上面的說明文檔就在此文件夾
├─ benchmarks                 // 基準,性能測試文件,Vue的跑分demo,比如大數據量的table或者渲染大量SVG
├─ dist                       // 構建后輸出的不同版本Vue文件(UMD、CommonJS、ES 生產和開發包)
├─ examples                   // 部分示例,用Vue寫的一些小demo
├─ flow                       // flow 因為Vue使用了 [Flow](https://flow.org/) 來進行靜態類型檢查,靜態類型檢查類型聲明文件
├─ packages                   // 包含服務端渲染和模板編譯器兩種不同的NPM包,是提供給不同使用場景使用的
├─ scripts                   // 存放npm腳本配置文件,結合webpack、rollup進行編譯、測試、構建等操作(使用者不需要關心)
│   ├─ alias.js              // 模塊導入所有源代碼和測試中使用的別名
│   ├─ config.js             // 包含在'dist/`中找到的所有文件的生成配置
│   ├─ build.js               // 對 config.js 中所有的rollup配置進行構建
├─ src                        // 主要源碼所在位置,核心內容
│   ├─ compiler               // 解析模版相關
│       ├─ codegen            // 把AST轉換為Render函數
│       ├─ directives         // 通用生成Render函數之前需要處理的指令
│       ├─ parser              // 解析模版成AST
│   ├─ core                    // Vue核心代碼,包括內置組件,全局API封裝,Vue 實例化,觀察者,虛擬DOM, 工具函數等等。
│       ├─ components          // 組件相關屬性,主要是Keep-Alive
│       ├─ global-api          // Vue全局API,如Vue.use,Vue.extend,Vue.mixin等
│       ├─ instance            // 實例化相關內容,生命周期、事件等
│       ├─ observer            // 響應式核心目錄,雙向數據綁定相關文件
│       ├─ util                // 工具方法
│       └─ vdom                // 包含虛擬DOM 創建(creation)和打補丁(patching) 的代碼
│   ├─ platforms               // 和平臺相關的內容,Vue.js 是一個跨平臺的MVVM 框架(web、native、weex)
│       ├─ web                 // web端
│           ├─ compiler        // web端編譯相關代碼,用來編譯模版成render函數basic.js
│           ├─ runtime         // web端運行時相關代碼,用于創建Vue實例等
│           ├─ server          // 服務端渲染
│           └─ util            // 相關工具類
│       └─ weex                // 基于通用跨平臺的 Web 開發語言和開發經驗,來構建 Android、iOS 和 Web 應用
│   ├─ server                  // 服務端渲染(ssr)
│   ├─ sfc                     // 轉換單文件組件(*.vue)
│   └─ shared                  // 全局共享的方法和常量
├─ test                        // test 測試用例
├─ types                       // Vue新版本支持TypeScript,主要是TypeScript類型聲明文件
├─ node_modules               // npm包存放目錄
|-- .babelrc.js               // babel配置
|-- .editorconfig             // 文本編碼樣式配置文件
|-- .eslintignore             // eslint校驗忽略文件
|-- .eslintrc.js              // eslint配置文件
|-- .flowconfig               // flow配置文件
|-- .gitignore               // Git提交忽略文件配置
|-- BACKERS.md               // 贊助者信息文件
|-- LICENSE                 // 項目開源協議
|-- package.json             // 依賴
|-- README.md               // 說明文件
|-- yarn.lock               // yarn版本鎖定文件

以上是“Vue的底層原理是什么”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

阳新县| 搜索| 遵化市| 翼城县| 察隅县| 乐至县| 于田县| 绥宁县| 克东县| 海门市| 武隆县| 长乐市| 丹寨县| 尼玛县| 淳安县| 扎赉特旗| 大英县| 宣汉县| 白水县| 阳山县| 运城市| 汉源县| 江口县| 津市市| 老河口市| 离岛区| 楚雄市| 澄江县| 云安县| 盘山县| 赤城县| 浦北县| 茂名市| 运城市| 苍山县| 龙江县| 叙永县| 调兵山市| 柳江县| 商都县| 江津市|