解决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 相关文章推荐
ASP SQL防注入的方法
Dec 25 Javascript
ie8模式下click无反应点击option无反应的解决方法
Oct 11 Javascript
js实现全国省份城市级联下拉菜单效果代码
Sep 07 Javascript
Asp.Net之JS生成分页条的方法
Nov 23 Javascript
微信小程序 ES6Promise.all批量上传文件实现代码
Apr 14 Javascript
React-router 4 按需加载的实现方式及原理详解
May 25 Javascript
基于iScroll实现下拉刷新和上滑加载效果
Jul 18 Javascript
Vue.js实现可配置的登录表单代码详解
Mar 29 Javascript
angular实现页面打印局部功能的思考与方法
Apr 13 Javascript
基于VUE实现的九宫格抽奖功能
Sep 30 Javascript
layui异步加载table表中某一列数据的例子
Sep 16 Javascript
javascript实现京东登录显示隐藏密码
Aug 02 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模拟SQL Server的两个日期处理函数
2006/10/09 PHP
PHP解密Unicode及Escape加密字符串
2015/05/17 PHP
实例说明js脚本语言和php脚本语言的区别
2019/04/04 PHP
yii框架数据库关联查询操作示例
2019/10/14 PHP
Javascript的IE和Firefox兼容性汇编
2006/07/01 Javascript
javascript的对话框详解与参数
2007/03/08 Javascript
jquery 插件开发方法小结
2009/10/23 Javascript
线路分流自动智能跳转代码,自动选择最快镜像网站(js)
2011/10/31 Javascript
document.all的一个比较完整的总结及案例
2013/01/31 Javascript
jquery foreach使用示例
2013/09/12 Javascript
jQuery 获取和设置select下拉框的值实现代码
2013/11/08 Javascript
javascript利用apply和arguments复用方法
2013/11/25 Javascript
jQuery不使用插件及swf实现无刷新文件上传
2014/12/08 Javascript
浅谈javascript构造函数与实例化对象
2015/06/22 Javascript
jQuery实现类似淘宝网图片放大效果的方法
2015/07/08 Javascript
JS+CSS实现类似QQ好友及黑名单效果的树型菜单
2015/09/22 Javascript
详解js界面跳转与值传递
2016/11/22 Javascript
jquery滚动条插件(可以自定义)
2016/12/11 Javascript
Webpack 服务器端代码打包的示例代码
2017/09/19 Javascript
Vue自定义指令写法与个人理解
2019/02/09 Javascript
javascript中call()、apply()的区别
2019/03/21 Javascript
ES6知识点整理之数组解构和字符串解构的应用示例
2019/04/17 Javascript
对python打乱数据集中X,y标签对的方法详解
2018/12/14 Python
python实现两个dict合并与计算操作示例
2019/07/01 Python
python多线程同步实例教程
2019/08/11 Python
python可迭代对象去重实例
2020/05/15 Python
python3 re返回形式总结
2020/11/20 Python
说一下Linux下有关用户和组管理的命令
2016/01/04 面试题
学校七一活动方案
2014/01/19 职场文书
团代会主持词
2014/04/02 职场文书
工作分析计划书
2014/04/30 职场文书
2014年教师节演讲稿
2014/09/03 职场文书
大学生党员学习焦裕禄精神思想汇报
2014/09/10 职场文书
保研专家推荐信范文
2015/03/25 职场文书
2015迎新晚会活动总结
2015/07/16 职场文书
2016年党员学习廉政准则心得体会
2016/01/20 职场文书