国产探花免费观看_亚洲丰满少妇自慰呻吟_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是該方法的別名

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东港市| 沐川县| 朔州市| 仙桃市| 大冶市| 常山县| 和田市| 绵竹市| 泽普县| 昔阳县| 静宁县| 景泰县| 寿光市| 绍兴市| 汪清县| 曲阜市| 潞城市| 拉孜县| 瑞安市| 革吉县| 桐城市| 望谟县| 大竹县| 突泉县| 日照市| 施秉县| 泸州市| 碌曲县| 五原县| 固安县| 儋州市| 淅川县| 达州市| 泰州市| 屏东市| 咸丰县| 雷州市| 阿克陶县| 洞口县| 平顺县| 鹿泉市|