国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

解決vue無法偵聽數組及對象屬性的變化問題

瀏覽:2日期:2023-01-06 16:12:37

一、數組

1、可以監聽到的情況

如push、splice、=賦值(array=[1,2,3])

2、無法監聽到的情況

使用下標修改某個元素(這種比較常見)

array[index] = 1

object.a = 3

直接修改數組length

array.length = 5

3、解決方案

this.$set(array, index, data) - 這是個深度的修改,某些情況下可能導致你不希望的結果,因此最好還是慎用this.dataArr = this.originArrthis.$set(this.dataArr, 0, {data: ’修改第一個元素’})console.log(this.dataArr) console.log(this.originArr) //同樣的 源數組也會被修改 在某些情況下會導致你不希望的結果

上面提到的splice方法進行增刪改

利用臨時變量進行中轉

let tempArr = [...this.targetArr]tempArr[0] = {data: ’test’}this.targetArr = tempArr

二、對象

對象和數組都是js里的引用類型,在實際存儲中,數據是存儲在堆中的,利用存儲在棧里的對象名或者數組名的指針進行索引,因此也存在在淺拷貝和深拷貝以及等號賦值時,到底是僅僅新建了一個指針指向了同一份數據,還是兩個指針分別指向了兩份完全一樣的數據的問題

1、可以監聽到的

對象的直接=賦值

this.obj = {name: ’test’}

2、無法監聽到的

對象屬性的增刪改

obj: { prop1: ’data1’, prop2: ’data2’}...// 增this.obj.prop3 = ’data3’// 刪delete this.obj.prop1// 改this.obj.prop1 = ’data4’

3、解決辦法

this.$set(obj, key ,value) - 可實現增、改watch時添加deep:true深度監聽,只能監聽到屬性值的變化,新增、刪除屬性無法監聽this.$watch(’blog’, this.getCatalog, { deep: true // immediate: true // 是否第一次觸發 });watch時直接監聽某個keywatch: { ’obj.name’(curVal, oldVal) { // TODO }}object.assign()+直接=賦值this.watchObj = Object.assign({}, this.watchObj, { name: ’xiaoyue’, age: 15,});

補充知識:vue 監聽不到數組或對象值的變化怎么辦

一、vue監聽數組的變化

vue能購監聽到數組變化的場景

通過賦值的形式改變正在被監聽的數組;

通過splice(index, num, val) 的形式改變正在被監聽的數組;

通過數組的push的形式改變正在被監聽的數組。

vue無法監聽數組變化的場景

通過數組索引改變數組元素的值;

改變數組的長度;

vue無法監聽數組變化的場景

this.$set(arr, index, newVal);

通過splice(index,num,val);

使用臨時變量作為中轉,重新賦值數組;

二、vue監聽對象的變化

vue能夠監聽到對象變化的場景

通過直接賦值的場景。

eg:watchObj = {name:“zyk”}

vue無法監聽到對象變化的場景

對象的增加、刪除、修改無法被vue監聽到

vue解決無法監聽對象變化的方法

使用 this.$set(object, key, value)(vue 無法監聽 this.set 修改原有屬性)

使用Object.assign(),直接賦值的原理;(推薦使用)

以上這篇解決vue無法偵聽數組及對象屬性的變化問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 甘南县| 保山市| 白山市| 道孚县| 孙吴县| 巴彦县| 建德市| 进贤县| 秀山| 永昌县| 陇川县| 丰都县| 张北县| 称多县| 成武县| 乌什县| 五莲县| 黑水县| 和政县| 蒲城县| 大关县| 荔浦县| 连南| 龙海市| 柳林县| 合肥市| 玉树县| 佛冈县| 莱西市| 湘西| 乌拉特前旗| 廉江市| 庄河市| 卫辉市| 玛纳斯县| 如皋市| 都昌县| 珲春市| 金坛市| 昭苏县| 开江县|