Vue底層實現原理概述


Vue是一個典型的MVVM框架,模型(Model)只是普通的JavaScript對象,修改它則視圖(View)會自動更新。這種設計讓狀態管理變得非常簡單而直觀。那么Vue是如何把模型和視圖建立起關聯的呢?

實現原理概述

這是前言提到的文章里的代碼,一段典型的體現了Vue特點的代碼:

<div id="mvvm-app">
    <input type="text" v-model="word">
    <p>{{word}}</p>
    <button v-on:click="sayHi">change model</button> //點擊這個button,word的值會發生改變
</div>

<script src="./js/observer.js"></script>
<script src="./js/watcher.js"></script>
<script src="./js/compile.js"></script>
<script src="./js/mvvm.js"></script>
<script>
    var vm = new MVVM({
        el: '#mvvm-app',
        data: {
            word: 'Hello World!'
        },
        methods: {
            sayHi: function() {
                this.word = 'Hi, everybody!';
            }
        }
    });
</script>

 

Vue實現這種數據雙向綁定的效果,需要三大模塊:

  1. Observer:能夠對數據對象的所有屬性進行監聽,如有變動可拿到最新值並通知訂閱者
  2. Compile:對每個元素節點的指令進行掃描和解析,根據指令模板替換數據,以及綁定相應的更新函數
  3. Watcher:作為連接Observer和Compile的橋梁,能夠訂閱並收到每個屬性變動的通知,執行指令綁定的相應回調函數,從而更新視圖

Observer

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

Watcher

Watcher訂閱者作為ObserverCompile之間通信的橋梁,主要做的事情是:

  1. 在自身實例化時往屬性訂閱器(dep)里面添加自己
  2. 自身必須有一個update()方法
  3. 待屬性變動dep.notice()通知時,能調用自身的update()方法,並觸發Compile中綁定的回調

Compile

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM