vue监听失效_解决Vue2.0 watch对象属性变化监听不到的问题

问题

很早之前就遇到一个问题,父组件向子组件传值,子组件监听传入对象的某个属性。发现子组件使用deep watch都不能观察到对象中属性的变化,今天终于找到为啥出现这种问题和解决办法了。

解决

为啥出现这种问题?受 ES5 的限制,Vue.js 不能检测到对象属性的添加或删除。

解决方式:

通过vue的this.$set(object, key, value)方法

通过Object.assign()重新创建一个对象, 例如this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 })

代码实例

方式一

方式二

export default {

data () {

return {

p: {a: 1}

}

},

methods: {

fun1 () {

console.log('click 1111')

// this.p.b = 2 // 通过点方法赋值,发现观察不到p的变化

this.$set(this.p, 'b', 2) // 第一种解决方式,可以查看日志看到已经监听到了变化

},

fun2 () {

console.log('click 2222')

this.p = Object.assign({}, this.p, {c: 3})

}

},

watch: {

p: {

handler (cval, oval) {

console.log('--------')

console.log(cval, oval)

},

deep: true

}

}

}

总结

个人推荐使用第二种解决方式,代码写起来更优雅。第一种解决方式如果有多个值会出现,多行$set()语句。

以上这篇解决Vue2.0 watch对象属性变化监听不到的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中的`watch`是一个响应式系统,用于监听数据的变动并执行相应的函数。然而,有时候可能会遇到`watch`监听不到数据变化的情况,这可能有以下几个原因: 1. **数据源问题**:确保你正在`watch`的数据绑定到了正确的变量或响应式属性上。如果数据是在组件之外定义的,或者使用了`v-model.lazy`这样的特殊行为,`watch`可能不会立即响应。 2. **依赖更新时机**:`watch`是异步的,特别是在首次设置时,会等到下一次数据更新循环(通常在DOM渲染后)才会开始监听。如果你期望立即生效,可以在`watch`回调中显式调用`$set`方法手动触发更新。 3. **深度监听**:默认情况下,`watch`只监听数据对象的浅层次属性。如果你需要监听嵌套对象或数组的变化,需要启用深度监听,通过在`watch`选项里添加`deep: true`。 4. **异步函数**:如果被监听的数据是由异步操作返回的,那么`watch`可能无法立即捕获到变化,因为数据还没有更新。在这种情况下,你可以考虑使用`async`和`await`,或者`immediate`选项。 5. **watch生命周期问题**:`watch`不是在每个属性改变时都执行的,而是根据Vue内部的策略来调度。如果你的监听函数在其他逻辑中修改了被观察的值,可能导致预期外的结果。 6. **惰性求值**:`watch`中的函数默认是惰性求值的,这意味着它们只有在第一次执行时才会被编译。如果你在`watch`回调里创建了新的函数或引用,这些可能不会被立即更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值