解决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 相关文章推荐
js正文内容高亮效果的实现方法
Jun 30 Javascript
js去除空格的12种实用方法
Nov 08 Javascript
使用CoffeeScrip优美方式编写javascript代码
Oct 28 Javascript
bootstrap fileinput 插件使用项目总结(经验)
Feb 22 Javascript
深入理解Vue.js轻量高效的前端组件化方案
Dec 10 Javascript
微信小程序控制台提示warning:Now you can provide attr "wx:key" for a "wx:for" to improve performance解决方法
Feb 21 Javascript
微信小程序常用赋值方法小结
Apr 30 Javascript
electron实现静默打印的示例代码
Aug 12 Javascript
JavaScript中0、空字符串、'0'是true还是false的知识点分享
Sep 16 Javascript
详解小程序云开发攻略(解决最棘手的问题)
Sep 30 Javascript
vue+node 实现视频在线播放的实例代码
Oct 19 Javascript
原生JS实现分页
Apr 19 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
日本因肺炎疫情影响,这几部动漫推延播放!
2020/03/03 日漫
重量级动漫纷纷停播!唯独OVERLORD第四季正在英魂之刃继续更新
2020/05/06 日漫
php curl获取网页内容(IPV6下超时)的解决办法
2013/07/16 PHP
老司机传授Ubuntu下Apache+PHP+MySQL环境搭建攻略
2016/03/20 PHP
半角全角相互转换的js函数
2009/10/16 Javascript
ie中js创建checkbox默认选中问题探讨
2013/10/21 Javascript
Js+Jq获取URL参数的集中方法示例代码
2014/05/20 Javascript
javaScript中两个等于号和三个等于号之间的区别介绍
2014/06/27 Javascript
基于NodeJS的前后端分离的思考与实践(四)安全问题解决方案
2014/09/26 NodeJs
用js编写的简单的计算器代码程序
2015/08/04 Javascript
微信小程序 loading(加载中提示框)实例
2016/10/28 Javascript
ES2015 Symbol 一种绝不重复的值
2016/12/25 Javascript
详解微信第三方小程序代开发
2017/06/23 Javascript
jQuery动画_动力节点节点Java学院整理
2017/07/04 jQuery
小程序指纹验证的实现代码
2018/12/04 Javascript
使用webpack/gulp构建TypeScript项目的方法示例
2019/12/18 Javascript
vue $mount 和 el的区别说明
2020/09/11 Javascript
JavaScript构造函数原理及实现流程解析
2020/11/19 Javascript
vue+element实现动态加载表单
2020/12/13 Vue.js
Python 3中的yield from语法详解
2017/01/18 Python
Python 正则表达式实现计算器功能
2017/04/29 Python
python模块之time模块(实例讲解)
2017/09/13 Python
Python带动态参数功能的sqlite工具类
2018/05/26 Python
在pandas多重索引multiIndex中选定指定索引的行方法
2018/11/16 Python
python实现美团订单推送到测试环境,提供便利操作示例
2019/08/09 Python
详解Python中的分支和循环结构
2020/02/11 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
Keras 在fit_generator训练方式中加入图像random_crop操作
2020/07/03 Python
python更新数据库中某个字段的数据(方法详解)
2020/11/18 Python
NFL Game Pass欧洲:在线观看NFL比赛直播和点播,以高清质量播放
2018/08/30 全球购物
RealTek面试题
2016/06/28 面试题
环保公益策划方案
2014/08/15 职场文书
给老婆的道歉信
2015/01/20 职场文书
2016年中秋节寄语大全
2015/12/07 职场文书
《陶罐和铁罐》教学反思
2016/03/03 职场文书
2022年显卡天梯图(6月更新)
2022/06/17 数码科技