技术文摘
Vue3 中 watch 与 watchEffect 使用实例解析
在Vue3的响应式编程中,watch与watchEffect是两个强大的工具,理解它们的使用实例对于开发者至关重要。
首先来看watch。watch主要用于监听一个或多个响应式数据源的变化,并在变化时执行相应的回调函数。它的基本语法是watch(source, callback, [options])。
假设我们有一个响应式数据:
import { ref, watch } from 'vue';
const count = ref(0);
watch(count, (newValue, oldValue) => {
console.log(`新值: ${newValue}, 旧值: ${oldValue}`);
});
count.value++;
这里,watch监听了count的变化,每当count的值改变,回调函数就会执行,打印出新值和旧值。
watch还可以监听多个数据源。例如:
const name = ref('');
const age = ref(0);
watch([name, age], ([newName, newAge], [oldName, oldAge]) => {
console.log(`新的姓名: ${newName}, 新的年龄: ${newAge}`);
console.log(`旧的姓名: ${oldName}, 旧的年龄: ${oldAge}`);
});
name.value = '张三';
age.value = 25;
通过传入一个数组作为数据源,我们可以同时监听多个响应式数据的变化。
再说说watchEffect。watchEffect会立即执行传入的一个函数,并响应式追踪其依赖,在依赖变化时重新执行。
import { ref, watchEffect } from 'vue';
const message = ref('');
watchEffect(() => {
console.log(`消息是: ${message.value}`);
});
message.value = 'Hello Vue3';
在这个例子中,watchEffect会立即执行回调函数,打印出初始的message值。当message的值发生变化时,回调函数会再次执行。
与watch不同,watchEffect不需要明确指定监听的数据源,它会自动收集依赖。这在很多场景下更加便捷,但也可能导致一些意外的重新执行。
在实际开发中,当我们需要精确控制监听的数据源和获取新旧值对比时,watch是一个不错的选择。而当我们只关心数据变化时的副作用操作,不关心具体的变化内容,watchEffect则更为合适。通过合理运用这两个工具,我们能够更高效地处理Vue3应用中的响应式逻辑,提升开发效率和代码质量。
TAGS: Vue3 watch watchEffect 使用实例解析
- Mysqlcheck 使用详解:检查、修复与优化表
- MySQL备份、还原及innoDB开启详细解析
- 深度解析 MySQL 利用正则实现字符串模糊替换的办法
- MySQL 数据库 shell 脚本自动备份详细介绍
- MySQL 简单使用详解与 JDBC 示例代码分享
- MySQL 使用 pt-query-digest 分析慢查询日志详情介绍
- MySQL 慢查询:开启慢查询的方法讲解
- 分享 Mysql GTID Mha 配置方法示例代码
- MySQL5.7不停业务下从传统复制变更为GTID复制示例代码详解
- MySQL:用一个语句查出各类整形占用字节数与最大最小值的示例代码
- Centos7 安装 mysql5.6.29 的 shell 脚本示例代码分享
- MySQL PXC 构建新节点仅需 IST 传输的方法详解
- MySQL常用语句全面总结及详细介绍
- Spring Boot 解决 Mysql 断连问题的详细使用方法
- Mysql数据库表定期备份实现示例代码详解