Vue2数据响应式再次理解

今天遇到一个问题吧算是,项目用的vue2,期望把数据的某个数组清空,在组件内部调用this.xxarray = [] 没问题,但是把数组引用传递到另外一个函数,执行赋值清空,会失效;大概的复原如下图

在这里插入图片描述
分析:vue2 采用defineproperty给内部的data等属性增加拦截器,对于数组对象等复杂数据类型,例如数组,只对其中的某些函数进行了重写在这里插入图片描述
也就是说 xxarray = [] 理论上是不被监听的,这样操作不会触发视图的更新。但是在组件内通过this.xxarray = []却可以,原因是this指向组件实例,也对其属性进行了监听,包括data中的数据,通过this来修改数组的值,是会被监听到的。但是如果把该数组的引用当作参数传递到另外一个函数进行操作,由于并没有经过this访问,且该赋值操作并不是vue重写数组的几个方法之一,自然不会被监听到,也就无法更新视图。
上面的现象都解释通了,还有一个问题就是上面第一个图的结果,为什么传递了数组的引用到另外一个函数,一开始两个引用是相同的,后面进行赋值操作后,两个引用不相等了。很好理解,纯js理解,看下图

在这里插入图片描述
一个数组作为参数传递到一个函数内部,是会新开一个函数空间,比如该函数里面的data变量,就是在这个空间的,数组作为参数传递的确实是引用,但是这个引用是赋值给data这个变量的,通过data去改变其中属性的值,可以,因为改的是数组内存地址的内容;但是如果直接改data,将其赋值为 [] 或者null,那就是把原来传入的引用抛弃,重新赋值给data,data指向变了,自然和原来的传入数组没啥关系了。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SuperHaker~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值