$watch中的oldvalue和newValue
大家都知道,在vue.js中给我们提供了$watch的方法来做对象变化的监听,而且在callback中会返回两个对象,分别是oldValue和newValue.
顾名思义,这两个对象就是对象发生变化前后的值。
但是在使用过程中我发现这两个值并不总是预期的。下面来一起看看详细的介绍:
定义data的值
rush:js;">
data: {
arr: [{
name: '笨笨',address: '上海'
},{
name: '笨笨熊',address: '北京'
}],obj: {
name: '呆呆',address: '苏州'
},str: '哈哈哈'
}
定义watch
rush:js;">
watch: {
arr: function(newValue,oldValue) {
console.log(newValue,oldValue)
console.log(JSON.stringify(oldValue) === JSON.stringify(newValue))
},obj: function(newValue,str: function(newValue,}
定义事件触发
rush:js;">
methods: {
test() {
this.arr.push({
name: 9
})
this.$set(this.obj,'i',0)
this.str = ''
},test1() {
this.arr = [{
name: '000'
}]
this.obj = {
name: 999
}
this.str = '123'
}
}
测试结果为
- 对数组进行push操作和对Obj进行$set操作,虽然都可能触发watch事件,但是在callback返回的结果中,oldValue和newValue相同。字符串对象如预期返回
- 在对数组和Obj统一进行赋值操作时,watch触发并且oldValue和newValue如预期返回
关于watch的其他测试
不能够触发监听的
1、数组
对某个下标重新赋值
2、对象
以上总结可能存在不足
万金油实现watch监听
array
rush:js;">
arr = [...arr]
obj
rush:js;">
obj = {...obj}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。