[vue]watch 的使用

vue 中 watch 监听

作用

主要用于监听值的变化

watch的使用

普通变量的监听

watch: {
    obj(new_value, old_value) {
        console.log(new_value, old_value)
    }
}

以上方式只会监听 obj 是否有值的变化,如果obj是个对象,含有属性,那么对象属性的值,如a的值发生了变化,不会触发watch

例如:

obj:{
    a:1
}

Object 监听–深度监听

watch: {

    obj:{
        handler(new_value,old_value){
            console.log(new_value,old_value)
        }
    },
    deep: true
}

添加deep属性,向下添加监听到每一个key,deep默认是false,这种可以监听a的变化,但是如果直接改变一个值无法触发watch,例如:

obj['a']=2

以上不会触发watch

如果需要改变内部值并且触发watch,需要用Vue.$set:

this.$set(tobj,'a',2)

如此,便可以触发watch

使用场景

父组件的值传递给子组件,如果传递的值为异步获取的值,那么子组件需要检测props值是否发生变更,以此用来更新子组件的初始化的值,此时需要用到watch

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三知之灵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值