vue中watch高级用法(deep和immediate)

一、handler方法和immdiate属性
watch默认绑定,页面首次加载时,是不会执行的。只有值发生改变才会执行。

 watch:{
     name:{
       handler(newName,oldName){
           //执行代码
       },

  immediate默认是false 改为true让他先去执行里面的handler方法,如果不写将不显示监听的初始值

       immediate:true //true就表示会立即执行
     }
 }

二、deep属性

如果是监听的是对象类型,当手动修改对象的某个属性时,发现是无效的。

data:{
    obj:{ name: '李四' }
},
watch:{
    obj:{
      handler(newName,oldName){
          //执行代码
      },
      deep:true //为true,表示深度监听,这时候就能监测到a值变化
    }
}

三、deep优化

可以使用字符串形式监听

data:{
  obj:{ name: '李四' }
},
watch:{
    'obj.name':{
      handler(newName,oldName){
          //执行代码
      },
      deep:true //为true,表示深度监听,这时候就能监测到a值变化
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值