Vue3-watch的用法

watch简介

作用:监视数据的变化 (和 Vue2 中的 watch 作用一致)

特点: Vue3 中的 watch 只能监视以下四种数据

1.ref 定义的数据(又可以分 基本对象 )

2.reactive 定义的数据

3.函数返回一个值。(getter 函数)

4.一个包含上述内容的数组

我们在 Vue3 中使用 watch 的时候,通常会遇到以下几种情况

情况一 (监视 ref 定义的[基本类型]数据)

监视 ref 定义的[基本类型]数据: 直接写数据名即可,监视的是其 value 值的改变

情况二 (监视 ref 定义的[对象类型]数据)

监视 ref 定义的[对象类型]数据: 直接写数据名,监视的是对象的[地址值]若想监视对象内部的数据,要手动开启深度监视。

注意

若修改的是 ref 定义的对象中的属性,newValue 和 oldValue 都是新值,因为它们是同一个对象

若修改整个ref 定义的对象,newValue 是新值, oldValue 是旧值,因为不是同一个对象了

情况三(监视reactive定义的对象类型数据)

监视reactive定义的对象类型数据,且默认开启了深度监视。

情况四(监视 ref 或 reactive 定义的[对象类型]数据中的某个属性)(关键)

监视 ref 或 reactive 定义的[对象类型]数据中的某个属性,注意点如下:

1.若该属性值不是[对象类型],是【基本类型】,需要写成函数形式。

2.若该属性值是依然是[对象类型],可直接编,也可写成函数,不过建议写成函数。

写成函数,不加deep,只监听地址变化;加deep,内部和地址都监听

不写成函数,只监听内部,整个对象都变了的时候,监听不到

结论:监视的要是对象里的属性,那么最好写函数式,注意点: 若是对象监视的是地址值,需要关注对象内部,需要手动开启深度监视。

情况五

监视上述多个数据

相关推荐
星空椰13 小时前
JavaScript 基础入门:从零开始掌握变量与数据类型
开发语言·前端·javascript·ecmascript
千寻简14 小时前
一个让 Claude Code 顺手很多的状态栏插件:claude-hud
前端·后端
掘金者阿豪14 小时前
数据库安全第一关:用户密码存储与认证机制的深度拆解
java·前端·后端
Ruihong14 小时前
你的 Vue 3 生命周期,VuReact 会编译成什么样的 React?
vue.js·react.js·面试
HelloReader14 小时前
QML 最佳实践写出高质量、可维护、高性能的代码(十二)
前端
HelloReader14 小时前
Qt Quick Controls 全览控件、弹窗、导航与样式定制(十一)
前端
意法半导体STM3214 小时前
【官方原创】STM32 USBx Host HID standardalone移植示例 LAT1449
开发语言·前端·stm32·单片机·嵌入式硬件
竹林81814 小时前
用wagmi v2构建DeFi前端:从连接钱包到读取合约数据的完整实战与避坑指南
前端·javascript
over69714 小时前
面试官视角:TypeScript Pick 工具类型深度解析与手写实现
前端·面试
木斯佳14 小时前
前端八股文面经大全:字节AIDP前端一面(2026-04-13)·面经深度解析
前端·音视频·webrtc·断点续传