源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-03-18 18:13 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:深入理解vue.js中$watch的oldvalue与newValue
[b]$watch中的oldvalue和newValue[/b] 大家都知道,在vue.js中给我们提供了$watch的方法来做对象变化的监听,而且在callback中会返回两个对象,分别是oldValue和newValue. 顾名思义,这两个对象就是对象发生变化前后的值。 但是在使用过程中我发现这两个值并不总是预期的。下面来一起看看详细的介绍: [b]定义data的值[/b]
data: {
 arr: [{
  name: '笨笨',
  address: '上海'
 }, {
  name: '笨笨熊',
  address: '北京'
 }],
 obj: {
  name: '呆呆',
  address: '苏州'
 },
 str: '哈哈哈'
 }
[b]定义watch[/b]
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))
 },
 }
[b]定义事件触发[/b]
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'
 }
 }
[b]测试结果为[/b] [list=1] [*]对数组进行push操作和对Obj进行$set操作,虽然都可能触发watch事件,但是在callback返回的结果中,oldValue和newValue相同。字符串对象如预期返回[/*] [*]在对数组和Obj统一进行赋值操作时,watch触发并且oldValue和newValue如预期返回[/*] [/list] [b]关于watch的其他测试[/b] [b]不能够触发监听的[/b] 1、数组         修改某个下标的某个属性的值         使用原生delete删除某个属性         对某个下标新增一个属性(不使用$set)         对某个下标重新赋值 2、对象         修改某个属性的值(但是会触发这个属性的监听)         新增一个属性(不使用$set)         原生delete删除某个属性 以上总结可能存在不足 [b]万金油实现watch监听[/b] 在修改完数据后添加这样一段代码 array
arr = [...arr]
obj
obj = {...obj}
[b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部