这篇文章主要为大家详细介绍了深入理解vue.js中$watch的oldvalue与newValue,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
大家都知道,在vue.js中给我们提供了$watch的方法来做对象变化的监听,而且在callback中会返回两个对象,分别是oldValue和newValue.
顾名思义,这两个对象就是对象发生变化前后的值。
但是在使用过程中我发现这两个值并不总是预期的。下面来一起看看详细的介绍:
代码如下:
data: {
arr: [{
name: '笨笨',
address: '上海'
}, {
name: '笨笨熊',
address: '北京'
}],
obj: {
name: '呆呆',
address: '苏州'
},
str: '哈哈哈'
}
代码如下:
watch: {
arr: function(newValue, oldValue) {
console.log(newValue, oldValue)
console.log(JSON.stringify(oldValue) === JSON.stringify(newValue))
},
obj: function(newValue, oldValue) {
console.log(newValue, oldValue)
console.log(JSON.stringify(oldValue) === JSON.stringify(newValue))
},
str: function(newValue, oldValue) {
console.log(newValue, oldValue)
console.log(JSON.stringify(oldValue) === JSON.stringify(newValue))
},
}
代码如下:
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'
}
}
1、数组
修改某个下标的某个属性的值
使用原生delete删除某个属性
对某个下标新增一个属性(不使用$set)
对某个下标重新赋值
2、对象
修改某个属性的值(但是会触发这个属性的监听)
新增一个属性(不使用$set)
原生delete删除某个属性
以上总结可能存在不足
在修改完数据后添加这样一段代码
array
代码如下:
arr = [...arr]
obj
代码如下:
obj = {...obj}
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对四海网的支持。
本文来自:http://www.q1010.com/184/3983-0.html
注:关于深入理解vue.js中$watch的oldvalue与newValue的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:vue.js
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。