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,内部和地址都监听

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

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

情况五

监视上述多个数据

相关推荐
Smile_2542204181 分钟前
vue3 + ts reactive方式清空表单对象
开发语言·前端·javascript
多租户观察室2 分钟前
信通院标准体系2.0深度解读:低代码管理平台进入“精品竞争”时代
前端·低代码·程序员
云水一下5 分钟前
CSS3从零基础到精通(四):终章大项目——纯CSS构建企业品牌展示网站
前端·css3
147API13 分钟前
Claude Opus 4.8 接口与工程落地分析:长任务调用链应该怎么设计
java·前端·数据库
李子琪。23 分钟前
Web 漏洞与防御机制实验报告
前端·经验分享
JustNow_Man26 分钟前
“失败后自动拉起修复 Agent”的闭环流水线
前端·人工智能·chrome·python
Dxy123931021629 分钟前
HTML中如何写键盘事件
前端·html·计算机外设
霍格沃兹测试学院-小舟畅学31 分钟前
接口自动化测试的下一个十年:从脚本到Skills,让AI学会“如何测”
java·前端·人工智能
huangfuyk33 分钟前
前端使用Cursor编辑器方面遇到的问题及注意细节
前端·编辑器·ai编程·cursor
ZC跨境爬虫36 分钟前
跟着 MDN 学CSS day_31:(精通链接样式,从伪类到导航菜单)
前端·javascript·css·ui·交互