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

首頁 > 編程 > JavaScript > 正文

淺談Vue的響應式原理

2019-11-19 11:25:46
字體:
來源:轉載
供稿:網友

一、響應式的底層實現

1、Vue與MVVM

Vue是一個 MVVM框架,其各層的對應關系如下

  • View層:在Vue中是綁定dom對象的HTML
  • ViewModel層:在Vue中是實例的vm對象
  • Model層:在Vue中是data、computed、methods等中的數據

在 Model 層的數據變化時,View層會在ViewModel的作用下,實現自動更新

2、Vue的響應式原理

Vue響應式底層實現方法是 Object.defineProperty() 方法,該方法中存在一個getter和setter的可選項,可以對屬性值的獲取和設置造成影響

Vue中編寫了一個wather來處理數據

在使用getter方法時,總會通知wather實例對view層渲染頁面
同樣的,在使用setter方法時,總會在變更值的同時,通知wather實例對view層進行更新
3、響應式原理與兼容

由于 Object.defineProperty() 方法只部分支持IE9,所以Vue兼容IE版本最低為IE9,在IE9中,Vue的核心框架、vue-router、vuex是確保可以正常使用的

4、響應式原理示意圖

1、在實例前聲明

var vm = new Vue({data: {name: "failte"}})

在實例前聲明的屬性會在實例時添加 getter()、setter() 方法,因此此時的name是響應式的,每當name變化時,會自動更新視圖

2、在實例后添加

vm.name = "failte"

由于data中沒有該屬性,因此實例后,此時的name是非響應式的,name變化時,不會更新視圖
若需要轉換為響應式數據,需要使用 Vue.set() 方法手動添加為響應式屬性

Vue.set(vm.data, "name", "ajaccio")//Vue.$set是該方法的別名

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 富蕴县| 通城县| 南和县| 张掖市| 上高县| 兰州市| 筠连县| 名山县| 雅安市| 夏河县| 凤凰县| 华阴市| 北票市| 长葛市| 四会市| 江北区| 霍林郭勒市| 寿光市| 东乡族自治县| 额尔古纳市| 浑源县| 郑州市| 浮梁县| 万荣县| 邹城市| 开远市| 沅陵县| 三江| 基隆市| 抚远县| 大英县| 凌海市| 谢通门县| 河间市| 镇江市| 灵璧县| 江华| 牟定县| 芮城县| 汝城县| 雅江县|