91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

淺談Vue的響應式原理

發布時間:2020-10-26 02:45:02 來源:腳本之家 閱讀:142 作者:fn-failte 欄目:web開發

一、響應式的底層實現

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、響應式原理示意圖

淺談Vue的響應式原理

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是該方法的別名

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

向AI問一下細節

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

AI

汉中市| 金门县| 信丰县| 平度市| 英德市| 铁岭县| 东方市| 米林县| 梁山县| 洛浦县| 洪洞县| 肇源县| 巴彦县| 万安县| 天门市| 商城县| 阳原县| 孟津县| 准格尔旗| 修文县| 元氏县| 长垣县| 南岸区| 安康市| 高雄市| 海伦市| 施秉县| 宝鸡市| 遵义县| 湖州市| 大悟县| 无锡市| 东光县| 南部县| 诸暨市| 贺兰县| 加查县| 海宁市| 富平县| 建昌县| 深圳市|