Vue3 watch监视和watchEffect函数

news2025/1/10 12:00:31

Vue3 中的watch使用效果和Vue2 中配置watch配置项的使用效果是一致的。

使用watch监视之前,需要先对watch进行引入。

import {watch} from 'vue';

一、监视一个ref对象

以下情况只适用于监视一个ref对象。

watch(监视对象, (newValue, oldValue) => {  // 监视操作  }, {  // 配置项  })

配置项中可以开启两个配置项:

1. immediate  是否初始化时对监视属性进行一次监听。

2. deep  是否开启深度监视。

使用ref定义的数据一般都是普通数据类型,不需要开启深度监视。

 

setup() {
  let num1 = ref(0);

  watch(num1, (newValue, oldValue) => {
    console.log(`num1从${oldValue}变为了${newValue}`);
  })

  return {
    num1,
  };
},

如果我们监视的是一个传入值为对象类型的ref 的对象,这种情况下我们是不能对该对象进行监听的,两种解决方法:

1. 使用.value 对数据进行监听,因为ref 对象的value值为一个reactive 对象。传入基本数据类型的ref 对象的value 仅仅只是一个传入的数据值。

2. 使用深度监视

二、监视多个ref对象

监视多个ref 对象的情况下,我们就要把监视对象写为一个数组。

watch ([对象1, 对象2], (newValue, oldValue) => {  // 监视操作  }, {  // 配置项  })

setup() {
  let num1 = ref(0);
  let num2 = ref(1);

  watch([num1, num2], (newValue, oldValue) => {
    console.log(oldValue, newValue);
  })

  return {
    num1,
    num2
  };
},

点击顺序为num1 + 1,num2 + 1,num1 + 1,num2 + 1。

oldValue和newValue都变为了一个数组,第一个属性的值为数组的第一项,第二个属性为数组的第二项,不管是哪一个属性变化,都会触发监听。 

 

 

三、监视所有reactive对象

watch (监视对象, (oldValue, newValue) => {  // 监视操作  }, {  // 配置项  })

这里的监视属性为reactive对象,也就是是一个对象类型或数组类型。

setup() {
  let person = reactive({
    name: "张三",
    age: 18,
    job: {
      type: "前端",
      salary:10
    }
  })

  watch(person, (newValue, oldValue) => {
    console.log("perosn变化了", oldValue, newValue);
  })

  return {
    person
  };
},

如果我们点击两下年龄+1和一下薪水+1,会发现两点变化:

1. 我们无法正确获得oldValue的值。

2. Vue3 为我们默认开启了深度监视,无法关闭。

 

五、监视一个reactive对象

如果我们只想要监视一个reactive 对象,监视属性就需要传入一个函数,返回需要被监视的值。

watch (() => 监视属性, (newValue, oldValue) => {  // 监听操作  }, {  // 配置项  })

我们可以根据监视对象的数据类型来判断是否开启深度监视:

如果我们监听的是对象,就需要开启深度监视;如果我们监听的是基本数据类型,就不需要开启深度监视。 

注意:是reactive对象自动开启了深度监视,reactive对象的属性值没有开启深度监视

setup() {
  let person = reactive({
    name: "张三",
    age: 18,
    job: {
      type: "前端",
      salary:10
    }
  })

  watch(()=>person.age, (newValue, oldValue) => {
    console.log("perosnd的name属性变化了", oldValue, newValue);
  })

  return {
    person
  };
},

六、监视多个reactive对对象 

监视多个reactive 对象依旧是写成数组的形式。

watch ( [() => 属性1, () => 属性2] ,  (newValue, oldValue) => {  // 监听操作  }, {  // 配置项  })

setup() {
  let person = reactive({
    name: "张三",
    age: 18,
    job: {
      type: "前端",
      salary:10
    }
  })

  watch([()=>person.age, ()=>person.job], (newValue, oldValue) => {
    console.log(oldValue, newValue);
  }, {deep:true})

  return {
    person
  };
},

这里我们开启了深度监视才能监听到salary 的变化。 

基本数据类型的oldValue 值是没问题的,对象数据类型的oldValue 依旧是有问题的。

 

七、watchEffect函数

watchEffect 函数和watch 函数不同的点在于,我们不需要跟watchEffect 指明我们到底需要监听哪个属性,只要我们在watchEffect 函数中使用到了哪个属性,就会监听哪个属性。

使用watchEffect 函数之前需要先对其进行引入:

import { watchEffect } from 'vue';

语法格式如下: 

watchEffect (() => {  // 监听逻辑  });

在下面的代码中,我们在watchEffect 中使用到了num 和 person.job.salary ,所以就会监听这两个值的改变。

setup() {
  let num = ref(0);
  let person = reactive({
    job: {
      type: "前端",
      salary: 10,
    },
  });

  watchEffect(() => {
    let x = num.value;
    let y = person.job.salary;
    console.log("watchEffect函数的回调被执行了",x ,y);
  });

  return {
    num,
    person,
  };
},

注意:watchEffect 默认开启了immediate,但没有开启深度监视,且不能进行配置项设置。

watchEffect 就类似于computed计算属性,都能够监视属性值的变化。

不过computed 注重的是数据变化后的返回结果,watchEffect 注重的是数据变化后的逻辑处理。 

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

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

相关文章

C++设计实现日志系统

转载:C设计实现日志系统 - 知乎 (zhihu.com) 日志系统几乎是每一个实际的软件项目从开发、测试到交付,再到后期的维护过程中极为重要的 查看软件代码运行流程、 还原错误现场、 记录运行错误位置及上下文等的重要依据。一个高性能的日志系统&#xff0c…

Spring Cloud学习(八)【RabbitMQ 服务异步通讯】

文章目录 初识 MQ同步通讯异步通讯MQ 常见框架 RabbitMQ 快速入门RabbitMQ 单机部署RabbitMQ概述常见消息模型 SpringAMQPSimpleQueue 模型WorkQueue 模型发布订阅模型发布订阅-Fanout Exchange发布订阅-DirectExchange发布订阅-TopicExchange消息转换器 初识 MQ 同步通讯 同步…

[Linux] DHCP网络

一、DHCP服务 1.1 DHCP的简介 DHCP(Dynamic Host Configuration Protocol,动态主机配置协议)通常被应用在大型的局域网络环境中,主要作用是集中地管理、分配IP地址,使网络环境中的主机动态的获得IP地址、Gateway地址…

Mistral 7B 比Llama 2更好的开源大模型 (二)

Mistral 7B 论文学习 Mistral 7B 论文链接 https://arxiv.org/abs/2310.06825 代码: https://github.com/mistralai/mistral-src 网站: https://mistral.ai/news/announcing-mistral-7b/ 论文摘要 Mistral 7B是一个70亿参数的语言模型,旨在获得卓越的性能和效率。Mistral 7…

【C++历险记】STL之set详解

个人主页:兜里有颗棉花糖💪 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【C之路】💌 本专栏旨在记录C的学习路线,望对大家有所帮助🙇‍ 希望我们一起努力、成长&…

29.第三方登录

1►第三方登录 当今社会,微信登录、QQ登录、抖音登录等等三方登录已经层出不穷,学会三方登录势在必行。 微信登录要认证开发者,必须为企业,个人不行,而且还要交300块钱。 QQ登录也要申请、微博登录也要申请。 还好…

为什么重写equals方法必须重写hashcode方法

在Java中,重写equals()方法的同时也应该重写hashCode()方法,这是因为这两个方法在 Java 中是有关联的,而且它们一起影响着集合类的行为。 Java中的hashCode()方法用于返回对象的哈希码,而equals()方法用于比较两个对象是否相等。…

[文件读取]webgrind 文件读取 (CVE-2018-12909)

1.1漏洞描述 漏洞编号CVE-2018-12909漏洞类型文件读取漏洞等级⭐⭐⭐漏洞环境VULFOCUS攻击方式 1.2漏洞等级 高危 1.3影响版本 Webgrind 1.5版本 1.4漏洞复现 1.4.1.基础环境 1.4.2.前提 网站后台地址: 后台管理账密: 后台登录地址 1.5深度利用 …

【rl-agents代码学习】02——DQN算法

文章目录 Highway-env Intersectionrl-agents之DQN*Implemented variants*:*References*:Query agent for actions sequence探索策略神经网络实现小结1 Record the experienceReplaybuffercompute_bellman_residualstep_optimizerupdate_target_network小结2 exploration_polic…

spring 整合 JUnit

大家好,本篇博客我们通过spring来整合JUnitt单元测试框架。 在之前篇章的测试方法中,几乎都能看到以下的两行代码: ApplicationContext context new ClassPathXmlApplicationContext("xxx.xml"); Xxxx xxx context.getBean(Xxx…

ppt画思路图 流程图 医学药学生画图素材

关注微信,回复: 素材 ,即可领取

EtherNET转Profibus网关使用 AB PLC的配置方法

兴达易控EtherNET转Profibus网关(XD-EPPB20)是一款功能强大的通讯设备,具备Profibus从站功能。它的主要作用是将EtherNET/IP设备无缝接入到PROFIBUS网络中。通过连接到Profibus总线,它可以作为从站使用,并且通过连接到…

作为8年老测试告诉你学会这样写性能测试方案,阿里p8都直呼内行

订单处理服务的性能测试方案V1.0 一、需求背景 在设计评审之后,开发在不知道服务性能瓶颈,需要测试协助定位服务的性能瓶颈,需要测试模拟一定时间之内设计并发用户同时向系统发出请求,检测出系统的响应能力,包括响应…

企业数字化建设之——老板关注的IT指标有哪些 ?

投资回报ROI | 商业价值 | 系统可用性 | 业务的参与程度 | 技术债务指数 降本,增效是IT部门工作的永恒话题 ,降低成本 ,增加效益 ,降本增效的工作方向: 1 年初KPI目标、目标完成情况、关键证据、公司主线工作…

腾讯云2核4G和4核8G服务器配置5年租用价格表

腾讯云服务器网整理五年云服务器活动 txyfwq.com/go/txy 配置可选2核4G和4核8G,公网带宽可选1M、3M或5M,系统盘为50G高性能云硬盘,标准型S5实例CPU采用主频2.5GHz的Intel Xeon Cascade Lake或者Intel Xeon Cooper Lake处理器,睿频…

Java的XWPFTemplate word生成列表

Java的XWPFTemplate工具类导出word.docx的使用_xwpftemplate 语法_youmdt的博客-CSDN博客 如果是表格的列表参考上面这篇文章即可,比较复杂的列表遍历暂时还没找到方法,只能手动创建表格了 上面是模板,非常简单,以为我们是要自己创…

SELF-AUGMENTED MULTI-MODAL FEATURE EMBEDDING

two embeddings f o r g _{org} org​ and f a u g _{aug} aug​ are combined using a gating mechanism 作者未提供代码

修改Conda虚拟环境默认位置失败——解决方案

修改虚拟环境默认安装位置依然❌ 偶然遇到conda创建虚拟环境创建失败的问题,按照教程修改.condarc文件中 envs_dirs:- E:\miniconda3\envs依然无法更改虚拟环境默认安装位置。 解决方案 找到想更改的虚拟环境文件位置,检查确认是否有写入权限&#…

C++ builder 常见问题汇总

1、CB静态编译设置 2、CB10.3设置经典编译器(用于解决10.3弹出代码提示慢) 3、CBuilder生成Release版本 : project->Options->CCompiler->Build Configuration 选择 Release project->Options->CLinker中取消Use dynamic RTL…

upload-labs关卡5(点和空格绕过)通关思路

文章目录 前言一、回顾上一关知识点二、靶场第五关通关思路1.看源代码2.点和空格绕过3、验证上传 总结 前言 此文章只用于学习和反思巩固文件上传漏洞知识,禁止用于做非法攻击。注意靶场是可以练习的平台,不能随意去尚未授权的网站做渗透测试&#xff0…