国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue底層實現原理總結

2024-05-06 15:21:45
字體:
來源:轉載
供稿:網友

前言

最近在研究 剖析Vue原理&實現雙向綁定MVVM 這篇文章,一邊學習一邊總結一下自己的思考。

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>

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

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

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

Watcher:作為連接Observer和Compile的橋梁,能夠訂閱并收到每個屬性變動的通知,執行指令綁定的相應回調函數,從而更新視圖

Observer

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

Watcher

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

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

Compile

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

總結

以上就是本次整理關于Vue底層實現原理的全部知識內容,如果大家還有任何不明白的地方可以在下方的留言區討論。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 罗平县| 绩溪县| 涿鹿县| 吕梁市| 兴仁县| 会东县| 政和县| 乐亭县| 栖霞市| 华池县| 淮南市| 衡阳县| 达州市| 康乐县| 永德县| 海阳市| 辽阳县| 大洼县| 洪雅县| 于都县| 平泉县| 武隆县| 沈阳市| 莎车县| 富顺县| 肃宁县| 诸城市| 上蔡县| 玛沁县| 丰镇市| 惠安县| 隆回县| 施秉县| 新蔡县| 中阳县| 凤凰县| 九龙城区| 绥德县| 乌拉特前旗| 民勤县| 霍州市|