技术文摘
Vue3 中 watchEffect 侦听器的使用方法
Vue3 中 watchEffect 侦听器的使用方法
在 Vue3 的响应式系统中,watchEffect 是一个强大且实用的侦听器工具,它为开发者提供了一种简洁而高效的方式来响应数据的变化。
watchEffect 会立即执行传入的一个函数,并响应式追踪其依赖,当依赖发生变化时会自动重新执行该函数。简单来说,它不需要像传统的 watch 那样明确指定要监听的数据源,而是自动收集依赖。
来看一个基本的使用示例。假设我们有一个响应式数据:
<template>
<div>
<p>{{ count }}</p>
<button @click="increment">Increment</button>
</div>
</template>
<script setup>
import { ref, watchEffect } from 'vue';
const count = ref(0);
const increment = () => {
count.value++;
};
watchEffect(() => {
console.log(`The value of count is: ${count.value}`);
});
</script>
在这个例子中,watchEffect 包裹的回调函数会立即执行一次,打印出初始的 count 值。每当 count 的值发生变化,回调函数就会再次执行,打印出新的值。
watchEffect 还支持清除副作用函数。在回调函数中返回一个函数,这个返回的函数会在侦听器停止或依赖更新前执行,用于清理一些副作用,比如定时器或事件监听器。
<template>
<div>
<p>{{ message }}</p>
<button @click="changeMessage">Change Message</button>
</div>
</template>
<script setup>
import { ref, watchEffect } from 'vue';
const message = ref('Initial Message');
const changeMessage = () => {
message.value = 'New Message';
};
watchEffect((onInvalidate) => {
const intervalId = setInterval(() => {
console.log('This is a side effect');
}, 1000);
onInvalidate(() => {
clearInterval(intervalId);
});
});
</script>
这里,在 watchEffect 的回调中设置了一个定时器,返回的清除函数会在 watchEffect 停止或依赖变化时清除定时器。
另外,watchEffect 也可以接收一个选项对象,其中包括 flush 和 onTrack、onTrigger 等属性。flush 选项可以控制副作用刷新的时机,有 'pre'(默认,在组件更新前触发)、'post'(在组件更新后触发)和 'sync'(同步触发) 等选项。
Vue3 的 watchEffect 侦听器极大地简化了我们处理响应式数据变化的逻辑,合理使用它可以让代码更加简洁和易于维护。无论是简单的数据监听还是复杂的副作用管理,watchEffect 都能发挥重要作用。
TAGS: Vue3 使用方法 watchEffect 侦听器
- 一日一技:几行代码助强迫症患者记得拔电源
- 探究 C 语言类型转换的内幕
- 事件驱动架构与微服务架构的差异及关联
- ES已过时?ClickHouse实力更强
- 实用爬虫经验,与您一同分享
- 面试官新花样:For 循环中 i++ 与 ++i 谁效率更高?
- 利用 BufferedReader 和 BufferedWriter 类完成文件拷贝
- 携程、蘑菇街与 bilibili:手写数组去重及扁平化函数
- UCSD 研究团队推出 SugarCoat 开源隐私保护工具 保障安全上网
- HarmonyOS ArkUI 自定义组件之侧滑菜单(JS)
- 深入了解 Node.js 只需一篇
- Netty 下代理网关的设计与实现
- 低代码开发鸿蒙应用 UI 手把手教学
- LeetCode - 字符串的之字形转换
- WorkManager 从入门至实践,一篇足矣