watch监听不到数组对象的变化

Vue不能监听到数组和对象值的变化其实和双向绑定的原理有关。Vue双向绑定原理是利用js中的Object.defineproperty重定义对象的GET和SET方法,而同时这种方法存在着缺陷。就是只能监听到对象内已有的值。在监听对象中属性变化的方法中中,无疑是使用ES6的proxy更为优越。

**总结:
如果操作对象是数组,改变数组的值用Vue的 s e t 方法,改变数组的长度用数组的 s p l i c e 方法使数组变化变成可监听的。如果操作对象是对象。如果操作的属性是对象内已经有的值,使用 set方法, 改变数组的长度用数组的splice方法使数组变化变成可监听的。 如果操作对象是对象。 如果操作的属性是对象内已经有的值,使用 set方法,改变数组的长度用数组的splice方法使数组变化变成可监听的。如果操作对象是对象。如果操作的属性是对象内已经有的值,使用watch,加上关键字deep深度监听对象,
如果操作的属性是对象内没有的新属性。使用$set使对象变成可监听的!
**

链接: https://blog.csdn.net/qq_38280242/article/details/102807862

一、利用索引直接改变arr的值

//普通监听
watch:{
    arr:function (newValue,oldValue) {
         console.log('arr改变了')
     },
}
// this.arr=[1,2,3,4]
this.arr[0]=100  //watch监听不到数组变化
this.$set(this.arr,0,1234) //能监听到数据

二、修改数组的长度arr.length

//普通监听
watch:{
    arr:function (newValue,oldValue) {
         console.log('arr改变了')
     },
}
// this.arr=[1,2,3,4]
this.arr.length=2   //watch监听不到数组变化
this.arr.splice(0,2)   //能监听到数据

三、添加和修改对象属性和值

//普通监听
watch:{
   obj:{
      handel:function (newValue,oldValue) {
          console.log('obj改变了')
      },
      deep:true
}
// obj:{   name:'wxs',
//          age:21   }
obj.name='xxx'   //watch监听不到数组变化要加上deep:true
this.$set(this.obj,'major','Vue')   //能监听到数据

链接: https://betheme.net/news/txtlist_i64894v.html?action=onClick

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值