深入理解vue.js中$watch的oldvalue与newValue

$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' } }

测试结果为

  1. 对数组进行push操作和对Obj进行$set操作,虽然都可能触发watch事件,但是在callback返回的结果中,oldValue和newValue相同。字符串对象如预期返回
  2. 在对数组和Obj统一进行赋值操作时,watch触发并且oldValue和newValue如预期返回

关于watch的其他测试

不能够触发监听的

1、数组

修改某个下标的某个属性的值

使用原生delete删除某个属性

对某个下标新增一个属性(不使用$set)

对某个下标重新赋值

2、对象

修改某个属性的值(但是会触发这个属性的监听)

新增一个属性(不使用$set)

原生delete删除某个属性

以上总结可能存在不足

万金油实现watch监听

修改完数据后添加这样一段代码

array

rush:js;"> arr = [...arr]

obj

rush:js;"> obj = {...obj}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持

相关文章

可以通过min-width属性来设置el-table-column的最小宽度。以...
yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
<el-form-item label="入库类型" ...
API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...