vue 监听map数组变化_解决vue无法侦听数组及对象属性的变化问题
一、数组
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 监听map数组变化_解决vue无法侦听数组及对象属性的变化问题相关推荐
- vue 组件第一次不渲染问题_解决vue页面渲染但dom没渲染的操作
我就废话不多说了,大家还是直接看代码吧~ this.$nextTick(() => { $("select[name='ddlCostCenter']").select2({ ...
- vue动态生成下拉框_解决vue动态下拉菜单 有数据未反应的问题
问题出现在当时后台数据会返回到data中但是没有出现下拉菜单,查询资料 发现 Vue的this理解有误 jsp 下拉菜单 {{item.plantModelName}} JS new Vue({ el ...
- vue上线后图片不显示_解决Vue打包后访问图片/图标不显示的问题
大家可否遇到过 npm run build打包后,项目在线上运行时,资源文件 (图片.图标)不显示 的问题, 接下来,我给大家分享一下我的解决方案~ 1.检查打包后dist中的css文件 打开此文件后 ...
- vue移动端点击事件延迟_解决Vue 界面在苹果手机上滑动点击事件等卡顿问题_莺语_前端开发者...
用 (1).滑动页面卡顿, (2).点击事件响应缓慢,百度才发现在苹果手机上有300ms的延迟. 一.滑动页面卡顿 //页面布局 页面内容 在对应的组件的最外层div上加上这样的样式: .conten ...
- vue样式中背景图片路径_解决vue打包css文件中背景图片的路径问题
vue-cli写完的静态页面我们在node环境中引入没有问题,但是打包后放在Apache环境下,路径却有问题了 如一个简单css语句 .welcome { width: 420px; height: ...
- 如何解决Linux下侦听端口被占用
本文介绍了 Linux 下随机端口和侦听端口重复的原因以及解决方法,虽然可以通过设置本地保留端口来解决,但这毕竟需要多一步配置操作,而且如果服务迁移到其他机器或者当前机器上有服务使用新的侦听端口,还得 ...
- vue watch 监听不到变化_关于vue中watch检测到不到对象属性的变化的解决方法
前言 在vue开发的过程中发现一个问题:改变vue.$data中对象的属性,watch是观测不到变化,但其实对象的属性是有变化的.这--,有点难以置信! 正文 update age with 25 e ...
- elementui 样式渲染的慢_解决vue+elementui项目打包后样式变化问题
博主刚刚解决了index.html空白问题,刚打开项目页面又发现了样式出现了大问题,样式与开发版本有很大不同,有些样式没有生效.利用搜索引擎, 找到了问题所在以及解决办法: main.js中的引入顺序 ...
- vue计算多列和_解决vue 表格table列求和的问题
最近在给朋友做一个项目,因为是B端,所以少不了表格. 本身就用了element-ui,但是订单管理有个需求使用element-ui table组件实现不了,只能退而求其之用了原生的table,功能是几 ...
最新文章
- Win32汇编基本编程框架
- QDoc格式特定的配置变量
- python入门(1)python的前景
- 通俗易懂,快速幂基本思想
- Ant-design-vue定制主题色
- hive linux进程数,控制Hive MAP个数详解
- 同态滤波(光照不均)
- 埋葬了我曾经的执着与思恋题记不过是所谓的世界末日
- Acrel-EMS企业微电网能效管理平台在某食品加工厂35kV变电站案例分享-安科瑞 周莉娜
- littleVGL学习笔记9——lv_btn 按钮
- Java实现屏幕截屏
- Java初学者零基础分章学习后续
- Python字符串操作集锦之字符串映射表
- johnson_trotter(生成排列算法)
- 【微信小程序】一文带你吃透小程序开发框架——视图层中的事件系统
- 【GitLab】GitLab数据自动删除、自动备份
- 给深度学习计算机视觉方向求职者的建议
- 用PS怎样处理一张文件照片,打印出来呈灰色不够清晰的纸张,使文字更黑,纸张更白
- 商业周刊:MySpace兴衰沉浮启示录(转)
- python图像腐蚀处理_Python图像处理之膨胀与腐蚀的操作
热门文章
- 双端堆c语言,数据结构——双端堆(C语言)
- jsp springmvc 视图解析器_Java面试题整理——SpringMVC
- Ubuntu设置root登录
- win7个人计算机的ip地址,win7计算机ip地址查询_win7本机ip地址查询
- html和css哪个优先,CSS3 | 样式和优先级
- python怎么加图片_python中如何保存图片
- caffe运行不停止_caffe(gpu)安装过程及问题解决
- html dom透明度,HTML DOM Style overflow 属性
- 中国石油计算机文化基础答案,中国石油大学17年秋《计算机文化基础》第二次在线作业答案...
- conda失败说没有写权限_爱情中,为什么男生表白失败,女生还说可以继续做朋友,想过没有...