Array.prototype.push.apply(arr1, arr2)在vue中不会触发dom更新

Array.prototype.push.apply(arr1, arr2)在vue中不会触发dom更新

export default {
	data() {
	return {
		 arr1: []		
    }
}

昨天做项目遇到两个数组合并,把数组2合并到数组1
使用了Array.prototype.push.apply(arr1, arr2)
发现数组是合并了,但dom上执行v-for 并没有发生任何改变
但奇怪的是改成 arr1.push.apply(arr1, arr2) 就会触发dom更新

输出了一下 arr1.__proto__ === Array.prototype 结果为 false
在这里插入图片描述
很明显这两者是不相等的
arr1.__proto__.__proto__ === Array.prototype 则会true

猜想vue源码应该是修改了Array.prototype.push()方法,引用的时候调用的应该是修改后的方法。
应该是只有在vue已经进行观察的数组上调用的方法添加的数据才会被加上observe

2020.12.28
查看源码刚好回顾到这个问题,原因是因为vue2实现监听数据变化的方法使用的是Object.defineProperty 这个方法并不能监听到数组的变化,所以vue在源码中对数组的一些原型方法进行了改写,调用真正的原型方法后在进行触发视图更新。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值