踩坑:Vue3 中的watch监视属性

news2025/1/10 21:46:25

文章目录

  • 一、问题一:reactive 定义的响应式数据无 oldValue
    • 问题
    • 分析
    • 解决
  • 二、问题二:watch默认开启了深度监视且无法关闭
    • 问题
    • 分析
    • 解决

一、问题一:reactive 定义的响应式数据无 oldValue

问题

  • 监视 reactive 所定义的一个响应式数据,是无法正确获取到 oldValue 的
  • 源码如下:
<script setup lang="ts">
import { ref, reactive, watch } from "vue";

const dataInfo = reactive(
  {
    'name': '法外狂徒张三',
    'age': 15
  }
)

watch(dataInfo, (newValue, oldValue) => {
  console.log(newValue, oldValue);
})

setTimeout(() => {
  dataInfo.age++;
  dataInfo.name += '!'
}, 5200);
</script>
  • 运行结果如下
    在这里插入图片描述
  • 从运行结果可以看出,获取到的 newValue 和 oldValue 两者是一样的

分析

我们从 Vue3 官网可以了解到: newValue 此处和 oldValue 是相等的, 除非 state.someObject 被整个替换了
在这里插入图片描述

解决

开发中如果要用到 oldValue 的值,可以对象中的该值单独提出作为 ref 去包裹使用

二、问题二:watch默认开启了深度监视且无法关闭

文章目录

  • 一、问题一:reactive 定义的响应式数据无 oldValue
    • 问题
    • 分析
    • 解决
  • 二、问题二:watch默认开启了深度监视且无法关闭
    • 问题
    • 分析
    • 解决

问题

  • 当我们想要监视一个多层级的数据时,Vue2 需开启深度监视,但Vue3会默认开启,当我们选择关闭深度监视时,时无法关闭的
  • 源码如下:
<script setup lang="ts">
import { ref, reactive, watch } from "vue";

const dataInfo = reactive(
  {
    'name': '法外狂徒张三',
    'age': 15,
    'data':{
	    data1:1,
	    data2:2,
  }
)

watch(dataInfo, (newValue, oldValue) => {
  console.log(newValue, oldValue);
}{deep:false})

setTimeout(() => {
  dataInfo.data.data1++;
  dataInfo.name += '!'
}, 5200);
</script>

分析

当我们想要监视一个多层级的数据时,Vue2 需开启深度监视,但Vue3会默认开启,当我们选择关闭深度监视时,时无法关闭的

解决

监视 reactive 定义响应式对象的向里一级,开启深度监听 deep:true 是有用的

<script setup lang="ts">
import { ref, reactive, watch } from "vue";

const dataInfo = reactive(
  {
    'name': '法外狂徒张三',
    'age': 15,
    'data':{
	    data1:1,
	    data2:2,
  }
)

watch(dataInfo.data, (newValue, oldValue) => {
  console.log(newValue, oldValue);
}{deep:true})

setTimeout(() => {
  dataInfo.data.data1++;
  dataInfo.name += '!'
}, 5200);
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/670981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

linux安装git步骤;基于yum、dnf、源码安装【非常详细】

这里写目录标题 一 dnf安装二 yum安装三 源码安装1 基于 RPM 的发行版&#xff08;Fedora/RHEL/RHEL衍生版&#xff09;2 基于 Debian 的发行版&#xff08;Debian/Ubuntu/Ubuntu-derivatives&#xff09;3 yum软件包管理器来安装&#xff0c;这个一般是CnetOS Stream 8以前的版…

POLARDB IMCI 白皮书 云原生HTAP 数据库系统 一 与其他的商业数据库在HTAP的异同点(译)...

开头还是介绍一下群&#xff0c;如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;在新加的朋友会分到2群&#xff08;共…

​关于 O2OA (翱途) 软件商用许可证授权形式的调整​

尊敬的小伙伴们&#xff1a; 非常感谢您对 O2OA 开发平台的关注与支持&#xff01; 兰德网络 O2OA 平台软件商用许证授权形式正式由 “按年授权” 改为 “按版本买断” 的永久许可形式。 这意味着&#xff0c;合作伙伴在持有特定版本的软件商用许可后&#xff0c;将能够永久…

《Python精选300题》

专栏简介 Python 是一门功能强大的编程语言&#xff0c;已经成为了数据科学、机器学习、Web 开发等领域的首选语言之一。因此&#xff0c;掌握 Python 的相关知识点对于学习和使用这门语言至关重要。 本专栏中&#xff0c;精选了 300 道题目&#xff0c;囊括了 Python 入门阶段…

什么是链表?

链表 什么是链表&#xff1f; 链表是有序的数据结构&#xff0c;链表中的每个部分称为节点。可以首、尾、中间进行数据存取&#xff0c;链表的元素在内存中不必是连续的空间&#xff0c;每个节点通过 next 指针指向下一个节点。 优点 链表的添加和删除不会导致其余元素位移。…

java中synchronized和ReentrantLock的加锁和解锁能在不同线程吗?如果能,如何实现?

java中synchronized和ReentrantLock的加锁和解锁能在不同线程吗&#xff1f;如果能&#xff0c;如何实现&#xff1f; 答案2023-06-21&#xff1a; java的&#xff1a; 这个问题&#xff0c;我问了一些人&#xff0c;部分人是回答得有问题的。synchronized这是个关键字&…

23---WPF数据库ORM框架

一、仓库--存放货物---数据库--存放数据--关系型数据/非关系型数据库 1.关系型数据:保存数据保存关系--SqlServer&#xff0c;MySql&#xff0c;Oracle 2.非关系型数据&#xff1a;保存数据---Redis,Mongo,Memecahe 二、关系型数据和非关系型数据的区别&#xff1a; 1.关系…

高效底座模型LLaMA

论文标题&#xff1a;LLaMA: Open and Efficient Foundation Language Models 论文链接&#xff1a;https://arxiv.org/abs/2302.13971 论文来源&#xff1a;Meta AI 一、概述 大型语言模型&#xff08;Large Languages Models&#xff0c;LLMs&#xff09;通过大规模文本数据的…

Selenium 环境配置

如果你做过 Web 测试的工作&#xff0c;那么你应该明白 Web 测试中最重要的一部分工作就是自动化测试。自动化测试&#xff0c;顾名思义就是让浏览器自动运行&#xff0c;而无需手动操作。这和我们爬虫工作原理有些相似&#xff0c;我们爬虫也需要让浏览器运行网址来获取我们需…

HTTPS加密

目录 HTTPS加密1.加密和解密2.对称加密3.非对称加密4.中间人攻击5.证书 HTTPS加密 1.加密和解密 1.明文: 要传递的原始信息。 2.密文: 经过加密后的信息。 3.加密就是指将明文&#xff08;要传输的信息&#xff09;按照指定的方式进行变换&#xff0c;生成密文。 4.解密…

Pytest+selenium+allure+Jenkins自动化测试框架搭建及使用

一、 环境搭建 1. Python下载及安装 Python可应用于多平台包括windows, Linux 和 Mac OS X, 本文主要介绍windows环境下。你可以通过终端窗口输入 "python" 命令来查看本地是否已经安装Python以及Python的安装版本。 如未安装python, 推荐下载python 3.8.3以…

Android——事务处理(续)(十三)

1. 长按事件 1.1 知识点 &#xff08;1&#xff09;掌握长按事件的操作形式&#xff1b; &#xff08;2&#xff09;可以设置手机的桌面背景&#xff1b; 1.2 具体内容 范例&#xff1a;长按一张图片之后&#xff0c;此图片设置为手机桌面背景。 <LinearLayout xmlns:a…

LocalDateTime 和 LocalDate 与 date 有什么区别;LocalDateTime 示例,LocalDate 示例

目录 1 LocalDateTime 和 LocalDate 与 date 有什么区别2 LocalDateTime 示例&#xff1a;2 LocalDate 示例&#xff1a; 1 LocalDateTime 和 LocalDate 与 date 有什么区别 LocalDateTime、LocalDate和Date是 Java中不同的类库中用于表示日期和时间的类&#xff0c; 它们在功…

「Java核心技术大会 2023」6月重磅启动,邀你共同探讨Java生态

前言 &#x1f4d5;作者简介&#xff1a;热爱跑步的恒川&#xff0c;致力于C/C、Java、Python等多编程语言&#xff0c;热爱跑步&#xff0c;喜爱音乐的一位博主。 &#x1f4d7;本文收录于恒川的日常汇报系列&#xff0c;大家有兴趣的可以看一看 &#x1f4d8;相关专栏C语言初…

《机器学习公式推导与代码实现》chapter13-LightGBM

《机器学习公式推导与代码实现》学习笔记&#xff0c;记录一下自己的学习过程&#xff0c;详细的内容请大家购买作者的书籍查阅。 LightGBM 就GBDT系列算法的性能而言&#xff0c;XGBoost已经非常高效了&#xff0c;但并非没有缺陷。LightGBM就是一种针对XGBoost缺陷的改进版…

【C++11】 列表初始化 auto 范围for 新增关键字 新增容器

文章目录 1 列表初始化2 auto && 范围for3 新增关键字3.1 decltype3.2 default3.3 delete3.4 final与override 4 总结 1 列表初始化 由c语言的规则我们知道&#xff1a;一般只有数组才会支持用{}初始化&#xff0c;但是C11新语法规定我们不仅可以用{}初始化各种对象(内…

企业微信 创建应用后如何构造网页授权 获取token 获取用户信息

第一次对接企业微信&#xff0c;上网找了各种方案。 目的是在企业微信中&#xff0c;公司发给员工一个地址&#xff0c;员工点开后打开画面&#xff0c;在这个画面上可以获取到这个员工的userid&#xff08;后续功能操作就是各自不同的功能了哈&#xff0c;就不详细说了&#…

STM32F4_触摸屏

目录 1. 触摸屏原理 2. 电阻式触摸屏检测原理 3. 电容式触摸屏检测原理 4. 硬件配置 4.1 XPT2046驱动芯片 4.2 硬件设计 5. 代码详解 5.1 main.c 5.2 AT24C02.c 5.3 AT24C02.h 5.4 C_Touch_I2C.c 5.5 C_Touch_I2C.h 5.6 Touch.c 5.7 Touch.h 5.8 FT5206.c 5.9 …

ADAudit Plus:保护企业内部IT安全的强大解决方案

随着企业数字化的推进&#xff0c;IT系统和数据安全变得比以往任何时候都更加重要。为了保护企业的机密信息和敏感数据&#xff0c;企业需要一种可靠的IT安全解决方案。在众多选项中&#xff0c;ADAudit Plus是一款备受赞誉的软件&#xff0c;为企业内部的IT安全提供了强大的支…

Python入门自学进阶-Web框架——36、Web微信类实现初步

打开页面&#xff0c;会出现一个二维码&#xff0c;要使用手机微信扫一扫&#xff0c;才能登录。它的实现原理是什么&#xff1f; 下图为打开网页版微信登录的调试工具网络信息&#xff0c;定时发送请求&#xff0c;状态待处理&#xff08;pending&#xff09; 上图的挂起是pe…