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

溫馨提示×

溫馨提示×

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

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

Vue2中無法檢測到數組變動怎么解決

發布時間:2022-05-05 18:21:13 來源:億速云 閱讀:386 作者:zzz 欄目:大數據

今天小編給大家分享一下Vue2中無法檢測到數組變動怎么解決的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

  • 解決方法

由于JavaScript 的限制,Vue 不能檢測以下數組的變動:

  • 當利用索引直接設置一個數組項時,例如:vm.items[indexOfItem] = newValue

  • 當修改數組的長度時,例如:vm.items.length = newLength

var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
  }
})
vm.items[1] = 'x' // 不是響應性的
vm.items.length = 2 // 不是響應性的

解決方法

手動添加監聽
// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
vm.$set(vm.items, indexOfItem, newValue)
使用數組的變異方法,因為vue對數組的變異方法實現了響應式
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)

為什么Vue2.0中監聽不到兩種數組的變化?

官方文檔中對于這兩點都是簡要的概括為“由于JavaScript的限制”無法實現,而Object.defineProperty是實現檢測數據改變的方案,那這個限制是指Object.defineProperty嗎?

其實原因并不是因為Object.defineProperty()存在漏洞,而是出于性能問題的考慮。 Object.defineProperty 在數組中的表現和在對象中的表現是一致的,數組的索引就可以看做是對象中的 key 。

  • 通過索引訪問或設置對應元素的值時,可以觸發 getter 和 setter 方法

  • 通過 push 或 unshift 會增加索引,對于新增加的屬性,需要再手動初始化才能被 observe 。

  • 通過 pop 或 shift 刪除元素,會刪除并更新索引,也會觸發 setter 和 getter 方法。

所以, Object.defineProperty 是有監控數組下標變化的能力的,只是vue2.x放棄了這個特性。

Vue2中無法檢測到數組變動怎么解決

源碼分析

Object.property是可以檢測到通過索引改變數組的操作的,而Vue沒有實現。那我們看看源碼:

Vue2中無法檢測到數組變動怎么解決

Vue3.0

Vue3.0中則用proxy代替了Object.defineProperty()解決了其存在的問題

以上就是“Vue2中無法檢測到數組變動怎么解決”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

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

vue
AI

靖边县| 专栏| 南汇区| 汨罗市| 永德县| 夹江县| 东源县| 汝南县| 海兴县| 宁强县| 梁山县| 友谊县| 申扎县| 长宁区| 泽库县| 河间市| 鹤峰县| 元谋县| 承德市| 阜南县| 黔江区| 平乐县| 宣汉县| 博湖县| 陇南市| 疏附县| 子长县| 长阳| 镇沅| 泾源县| 巴马| 会同县| 合肥市| 高唐县| 潞城市| 西青区| 白水县| 嘉定区| 喜德县| 抚顺县| 什邡市|