Vue之watch源码解读

本文深入探讨Vue的watch方法,从基本数据类型监听到对象的深度监听,再到watch接收数组参数的特殊用法。通过源码解析,揭示了Vue如何初始化watch,包括initState、initWatch和createWatcher的执行过程,以及Watcher对象的角色。文章还指出,watch不仅可以接受方法,还能接受字符串形式的处理函数,并在有immediate属性时,会在组件创建时立即触发。通过对源码的学习,可以发现一些官方文档未提及的使用技巧。
摘要由CSDN通过智能技术生成

回顾 watch 的用法

watch 是 Vue 中的一个监听数据变化的一个方法,我们在阅读源码之前先来回顾一下 watch 的用法

监听基本数据类型

<div>
  {
  { name }}
  <button @click="changeName">改变name</button>
</div>
export default {
  data() {
    return {
      name: 'maoxiaoxing',
    }
  },
  watch: {
    name(val, oldval) {
      console.log(val, oldval)
    }
  },
  methods: {
    changeName() {
      this.name = this.name === 'maoxiaoxing' ? 'yangxiaoA' : 'maoxiaoxing'
    }
  }
}

watch 可以接收两个参数,一个是变化之后的数据,一个是变化之前的数据,你可以基于这两个值处理一些逻辑

监听对象

<div>
  {
  { obj.name }}
  <button @click="changeName">改变name</button>
</div>
export default {
  data() {
    return {
      obj: {
        name: 'maoxiaoxing',
      }
    }
  },
  watch: {
    obj: {
      handler(val, oldval) {
        console.log(val, old
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值