vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > 取消Vue Watch监听

如何取消Vue Watch监听的方法示例

作者:我的写法有点潮

在实际项目中,watch 本质上是一种长期订阅关系,如果不加控制,它会在数据变化的整个生命周期内持续触发,这在很多场景下并不是我们想要的,所以我们有时会想取消Vue Watch监听,因此本文给大家介绍了取消Vue Watch监听的方法示例,需要的朋友可以参考下

1. 为什么要取消 Watch 监听?

在实际项目中,watch 本质上是一种长期订阅关系
如果不加控制,它会在数据变化的整个生命周期内持续触发,这在很多场景下并不是我们想要的。

合理地取消监听,主要有以下几个好处:

once 和手动取消监听的区别

Vue 3 提供了 once 选项,用来监听一次后自动销毁:

once

手动取消监听(stop)

2. Vue 2 中如何取消 Watch 监听

在 Vue 2 中,只有通过 this.$watch 创建的监听才能被手动取消

示例

const stop = this.$watch(
  'count',
  function (nval) {
    if (nval === 3) {
      stop()
    }
  }
)

const handleStopWatch = () => {
  stop()
}

这里需要注意一个关键点:

Vue 2 的选项式写法(watch: {})是没有返回值的,因此无法手动取消监听。

watch: {
  count(val) {
    // ❌ 这种方式无法取消
  }
}

如果你有「阶段性监听」或「一次性逻辑」的需求,就必须使用 this.$watch

3. Vue 3 中如何取消 Watch 监听

Vue 3(Composition API)对这点做了明显优化:
watch 本身就会返回一个停止监听的函数

示例

const count = ref(1)

const stop = watch(
  count,
  (nval) => {
    if (nval === 3) {
      stop()
    }
  }
)

const handleStopWatch = () => {
  stop()
}

可以看到,Vue 3 的写法在语义上更加清晰:

4. 总结

监听不是一直盯着,而是完成使命后及时退场。

到此这篇关于如何取消Vue Watch监听的方法示例的文章就介绍到这了,更多相关取消Vue Watch监听内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文