一、数组
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.originArr this.$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时直接监听某个key watch: { '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,侦听数组,对象属性
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]