解决vue无法侦听数组及对象属性的变化问题


Posted in Javascript onJuly 17, 2020

一、数组

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无法侦听数组及对象属性的变化问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 页面模板化很多人没有使用过的方法
Jun 05 Javascript
js动态给table添加/删除tr的方法
Aug 02 Javascript
捕获和分析JavaScript Error的方法
Mar 25 Javascript
jquery实现类似淘宝星星评分功能实例
Sep 12 Javascript
JavaScript使用setInterval()函数实现简单轮询操作的方法
Feb 02 Javascript
jquery实现的用户注册表单提示操作效果代码分享
Aug 28 Javascript
BootStrap使用popover插件实现鼠标经过显示并保持显示框
Jun 23 Javascript
Angular-Ui-Router+ocLazyLoad动态加载脚本示例
Mar 02 Javascript
js 奇葩技巧之隐藏代码
Aug 11 Javascript
Vue2实时监听表单变化的示例讲解
Aug 30 Javascript
Vue搭建后台系统需要注意的问题
Nov 08 Javascript
JS Canvas接口和动画效果大全
Apr 29 Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
Jul 17 #Javascript
Vue element-ui父组件控制子组件的表单校验操作
Jul 17 #Javascript
简单了解常用的JavaScript 库
Jul 16 #Javascript
jQuery加PHP实现图片上传并提交的示例代码
Jul 16 #jQuery
浅谈js中的attributes和Attribute的用法与区别
Jul 16 #Javascript
JS自定义右键菜单实现代码解析
Jul 16 #Javascript
JS如何在不同平台实现多语言方式
Jul 16 #Javascript
You might like
最准确的php截取字符串长度函数
2015/10/29 PHP
PHP curl 或 file_get_contents 获取需要授权页面的方法
2017/05/05 PHP
Yii2使用表单上传文件的实例代码
2017/08/03 PHP
js constructor的实际作用分析
2011/11/15 Javascript
js中indexof的用法详细解析
2013/12/24 Javascript
jquery复选框全选/取消示例
2013/12/30 Javascript
js加密解密字符串可自定义密码因子
2014/05/13 Javascript
JS 新增Cookie 取cookie值 删除cookie 举例详解
2014/10/10 Javascript
javascript数组去重的方法汇总
2015/04/14 Javascript
JavaScript改变CSS样式的方法汇总
2015/05/07 Javascript
jQuery添加删除DOM元素方法详解
2016/01/18 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
2016/03/01 Javascript
bootstrap vue.js实现tab效果
2017/02/07 Javascript
canvas实现探照灯效果
2017/02/07 Javascript
浅谈Webpack打包优化技巧
2018/06/12 Javascript
JS常见构造模式实例对比分析
2018/08/27 Javascript
mpvue项目中使用第三方UI组件库的方法
2018/09/30 Javascript
详解如何为你的angular app构建一个第三方库
2018/12/07 Javascript
详解如何更好的使用module vuex
2019/03/27 Javascript
Pyhton中单行和多行注释的使用方法及规范
2016/10/11 Python
对Python多线程读写文件加锁的实例详解
2019/01/14 Python
python实现批量视频分帧、保存视频帧
2019/05/31 Python
Django中使用CORS实现跨域请求过程解析
2019/08/05 Python
python实现3D地图可视化
2020/03/25 Python
pycharm使用技巧之自动调整代码格式总结
2020/11/04 Python
HTML5 Video/Audio播放本地文件示例介绍
2013/11/18 HTML / CSS
htmlentities() 和 htmlspecialchars()有什么区别
2015/07/01 面试题
线程问题:wait()方法是定义在哪个类里面
2015/07/07 面试题
网络工程系信息安全技术专业大学生求职信
2013/10/22 职场文书
公司董事长职责
2013/12/12 职场文书
上课说话检讨书大全
2014/01/22 职场文书
企业办公室主任岗位职责
2014/02/19 职场文书
读书小明星事迹材料
2014/05/03 职场文书
优秀管理者事迹材料
2014/05/22 职场文书
文明寝室标语
2014/06/13 职场文书
2022微信温控新功能上线
2022/05/09 数码科技