Vue 监听属性 watchEffect

watchEffect 函数:自动收集依赖源,不用指定监听哪个数据,在监听的回调中用到哪个数据,就监听哪个数据。

而 watch 函数:既要指定监听的数据,也要指定监听的回调。

watchEffect 函数:类似于 computed 计算属性,但是 watchEffect 注重的是过程(回调函数的函数体),所以不用写返回值。

而 computed 函数:更注重计算出来的值(回调函数的返回值),所以必须要写返回值。

watchEffect 函数的使用:

html 复制代码
<template>
    <h2>计数:{{ sum }}</h2>
    <button @click="sum++">点我加1</button>
    <hr />
    <h2>姓名:{{ info.name }}</h2>
    <h2>薪资:{{ info.job.money }}</h2>
    <button @click="info.name += '风'">修改姓名</button>
    <button @click="info.job.money++">增加薪资</button>
    <hr />
    <h2>年龄:{{ info.age }}</h2>
    <button @click="info.age++">修改年龄</button>
</template>

<script>
// 引入 watchEffect 侦听属性
import { watchEffect, ref, reactive } from 'vue'
export default {
    name: "Home",
    setup() {
        // 创建 ref 数据
        let sum = ref(0);
        // 创建 reactive 数据
        let info = reactive({
            name: "张三",
            job: {
                money: 20
            },
            age: 18
        });

        // 监听所用数据的变化
        watchEffect(() => {
            const x1 = sum.value; // 使用 ref 数据
            const x2 = info.name; // 使用 reactive 数据
            const x3 = info.job.money; // 使用深层数据
            console.log('watchEffect函数用到的数据变了');
            console.log(x1, x2, x3);
        })

        // 返回数据
        return { sum, info }
    }
}
</script>

注:watchEffect 函数不需要指定监听哪个数据,只要在 watchEffect 函数中用到的数据发生了变化,watchEffect 函数就会执行。

原创作者:吴小糖

创建时间:2023.10.31

相关推荐
Hexene...19 小时前
【前端Vue】出现elementui的index.css引入报错如何解决?
前端·javascript·vue.js·elementui
红色的小鳄鱼19 小时前
Vue 监视属性 (watch) 超全解析:Vue2 Vue3
前端·javascript·css·vue.js·前端框架·html5
web小白成长日记19 小时前
Vue-实例从 createApp 到真实 DOM 的挂载全历程
前端·javascript·vue.js
晚霞的不甘19 小时前
Flutter for OpenHarmony实现高性能流体粒子模拟:从物理引擎到交互式可视化
前端·数据库·经验分享·flutter·microsoft·计算机视觉
晚霞的不甘20 小时前
Flutter for OpenHarmony 流体气泡模拟器:用物理引擎与粒子系统打造沉浸式交互体验
前端·flutter·ui·前端框架·交互
colicode20 小时前
发送语音通知接口技术手册:支持高并发的语音消息发送API规范
前端
橙露20 小时前
前端性能优化:首屏加载速度提升的8个核心策略与实战案例
前端·性能优化
Access开发易登软件20 小时前
Access 中实现 Web 风格的顶部加载进度条
前端·数据库·vba·access·access开发
一起养小猫20 小时前
Flutter for OpenHarmony 实战:打造功能完整的记账助手应用
android·前端·flutter·游戏·harmonyos
hbstream海之滨视频网络技术20 小时前
Google正式上线Gemini In Chrome,国内环境怎样开启。
前端·chrome