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>
相关推荐
万少13 小时前
公测期 0 元/月!商汤 SenseNova 免费 Token 再不领就没了
前端·javascript·后端
Hello--_--World13 小时前
Webpack:Webpack 核心配置、什么是 Loader? 什么是plugin?webpack 构建流程
前端·webpack·node.js
专注VB编程开发20年13 小时前
专业分析python底层调用与按键精灵,ah3等的对比,hookdll,内存加载,调用.net dll
开发语言·javascript·python·microsoft·php·.net
invicinble13 小时前
前端框架使用vue-cli( 第二层:工程配置层--elementui需要做的基础配置)
vue.js·elementui·前端框架
优联前端13 小时前
什么是 GEO?SEO对比GEO,如何做好 GEO?怎么验证 GEO 效果?
前端·人工智能·用户体验·geo·seo优化·优联前端
时间不早了sss13 小时前
Python处理文档
开发语言·前端·python
invicinble13 小时前
前端框架使用vue-cli( 第二层:工程配置层--技术栈配置层配置)
javascript·vue.js·前端框架
Json____13 小时前
前端入门练习题集-HTML/CSS/JS实战小项目15个
前端·css·html
科研小白_13 小时前
【第二期:MATLAB点云处理基础】KD树与点云邻域搜索
java·前端·人工智能
小江的记录本13 小时前
【MySQL】《MySQL基础架构 面试核心考点问答清单》
前端·数据库·后端·sql·mysql·adb·面试