Vue中Watcher用法分析

Watch在一开始初始化的时候,会读取一次监听的数据的值。于是,这个值就收集到了Watch的watcher。而我们给Watch设置的handler,Watch会放入watcher中。当数据改变时,通知Watch的watcher进行更新,也是handler就被调用了。

如果我们设置了immediate: true,就不需要在数据变化时才触发,而是完成初始化之后,就立即执行一次handler。

如果我们设置了deep: true,如果被监听的值是对象,Vue会进行深度遍历。这个对象之下的每一个属性都会收集到这个Watch的watcher,当这个对象任意一个属性发生变化时,该Watch的handler就会被调用。

data() {
    return {
        a: {
            b: {
                c: 123
            }
        }
    }
}

比如我们坚挺了以上data中的a属性,那么a, b, c都会收集到这个Watch的watcher,当这3个任意一个发生变化是,Watch的handler就会被调用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值