watch与watchEffect的区别

watch与watchEffect的区别

给大家打一个比喻

watch:教导主任叫老师看张三和李四是否在睡觉

watchEffect:教导主任叫老师看班上有谁在睡觉,在睡觉的就报告

1.都能监听响应式数据的变化,不同的是监听数据变化的方式不同

2.watch:要明确指出监视的数据

csharp 复制代码
<template>
    <div>{{ sum1 }}</div>
    <div>{{ sum2 }}</div>
    <button @click="changeSum1">sum1+1</button>
    <button @click="changeSum2">sum2+1</button>
</template>
<script lang="ts" setup>
import { watch, ref } from "vue"
let sum1 = ref(0)
let sum2 = ref(1)
function changeSum1() {
    sum1.value += 1
}
function changeSum2() {
    sum2.value += 1
}
// 我们使用watch时需要指定监视的数据
watch([sum1, sum2], (newVal, oldVal) => {
    console.log(newVal, oldVal);
})
</script>
<style scoped></style>

3.watchEffect:不用明确的指出监视的数据(函数中用到哪些属性,就监视哪些属性)

csharp 复制代码
<template>
    <div>{{ sum1 }}</div>
    <div>{{ sum2 }}</div>
    <button @click="changeSum1">sum1+1</button>
    <button @click="changeSum2">sum2+1</button>
</template>
<script lang="ts" setup>
import { watchEffect, ref } from "vue"
let sum1 = ref(0)
let sum2 = ref(1)
function changeSum1() {
    sum1.value += 1
}
function changeSum2() {
    sum2.value += 1
}
// 我们使用watchEffect时不需要指定监听的数据
watchEffect(() => {
    console.log(sum1.value, sum2.value);
})
</script>
<style scoped></style>
相关推荐
Wect7 小时前
LeetCode 39. 组合总和:DFS回溯解法详解
前端·算法·typescript
Wect7 小时前
LeetCode 46. 全排列:深度解析+代码拆解
前端·算法·typescript
IT_陈寒7 小时前
Vite 凭什么比 Webpack 快50%?揭秘闪电构建背后的黑科技
前端·人工智能·后端
颜酱7 小时前
Dijkstra 算法:从 BFS 到带权最短路径
javascript·后端·算法
hi大雄8 小时前
我的 2025 —— 名为《开始的勇气》🌱
前端·年终总结
从文处安8 小时前
「前端何去何从」一直写 Vue ,为何要在 AI 时代去学 React?
前端·react.js
aircrushin8 小时前
OpenClaw“养龙虾”现象的社会技术学分析
前端·后端
明君879979 小时前
#Flutter 的官方Skills技能库
前端·flutter
yuki_uix9 小时前
重新认识 React Hooks:从会用到理解设计
前端·react.js
林太白9 小时前
ref和reactive对比终于学会了
前端