博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue中数组变动不被监测问题
阅读量:6293 次
发布时间:2019-06-22

本文共 1164 字,大约阅读时间需要 3 分钟。

前两天去玩了,接下来还有挺多学习目标的。今天来写的之前遇到的问题好了。

在之前的项目中,有时候需要对一个数组的某个元素进行改动(如:list[2] = 'b'),却发现改动了在视图上确没有变化,这是为什么呢?这个问题要如何解决呢?

问题产生的原因

让我们来看看vue中数据劫持的实现。

var data = {
name: 'kindeng'};observe(data);data.name = 'dmq'; // 哈哈哈,监听到值变化了 kindeng --> dmqfunction observe(data) { if (!data || typeof data !== 'object') { return; } // 取出所有属性遍历 Object.keys(data).forEach(function(key) { defineReactive(data, key, data[key]); });};function defineReactive(data, key, val) { observe(val); // 监听子属性 Object.defineProperty(data, key, { enumerable: true, // 可枚举 configurable: false, get: function() { return val; }, set: function(newVal) { observe(newVal) //对象新赋值时给新的属性添加订阅器 val = newVal; } });}复制代码

1、在上述代码中,只有类型为‘object’的变量,它下面的属性才会继续遍历,if (!data || typeof data !== 'object') {return;}。如果是个数组,则不会去遍历数组里面的东西。如:

var list = [a, b, c]复制代码

只对list做了劫持,而list下子属性则没有。

2、list是个引用类型,Object.defineProperty中的set只有在list的地址改变时才会被触发,list[2] = 'c'这样的操作不会引起地址改变。

解决问题的方法

vue中提供了set,手动的去添加监听。

//Vue.set( target, key, value )this.$set(this.list, 2, 'c')复制代码

另外,vue重写了数组的push、pop等方法,使这些操作下的变动可以被监听到。

转载地址:http://cptta.baihongyu.com/

你可能感兴趣的文章
python 内部函数,以及lambda,filter,map等内置函数
查看>>
大家猜猜看除了围棋,人工智能下一个颠覆的领域是什么?
查看>>
SharePoint 2013 数据库中手动更新用户信息
查看>>
SharePoint 2013 表单认证使用ASP.Net配置工具添加用户
查看>>
《C程序员:从校园到职场》出版预告(1):从“高大上”到“柴米油盐”
查看>>
李飞飞获全球最权威女性领导力奖 Athena Award,讲述推动AI多元化三大原因(视频)...
查看>>
线程堆栈大小 pthread_attr_setstacksize 的使用
查看>>
杀手洗车房:黑客能困住并攻击汽车
查看>>
云计算物联网Hold住未来十大技术趋势
查看>>
2016总结 - 我的转型之路
查看>>
优化Hadoop Balancer运行速度
查看>>
分析型数据库受大数据市场追捧
查看>>
深度学习训练,选择P100就对了
查看>>
ElasticSearch小操之Marvel,Sense
查看>>
[译] Redux 有多棒?
查看>>
Powershell 邮件发送
查看>>
创建代码生成器可以很简单:如何通过T4模板生成代码?[下篇]
查看>>
大数据时代分析师 Splunk助大数据落地
查看>>
【前沿】何恺明大神ICCV2017最佳论文Mask R-CNN的Keras/TensorFlow/Pytorch 代码实现
查看>>
云计算中心的实施技术
查看>>