快速打通 Vue 3(三):Vue3 中的 watch 监听器与新特性

news2024/12/29 9:10:40

很激动进入了 Vue 3 的学习,作为一个已经上线了三年多的框架,很多项目都开始使用 Vue 3 来编写了
这一组文章主要聚焦于 Vue 3 的新技术和新特性
如果想要学习基础的 Vue 语法可以看我专栏中的其他博客
Vue(一):Vue 入门与 Vue 指令
Vue(二):计算属性与 watch 监听器
Vue(三):Vue 生命周期与工程化开发
一篇文章快速通关 Vuex(适合小白学习)
Vue 框架前导:详解 Ajax
快速打通 Vue 3(一):基本介绍与组合式 API
快速打通 Vue 3(二):响应式对象基础
上一篇 Vue3 博客:快速打通 Vue 3(二):响应式对象基础
后续还会继续更新,期待大家的关注!

05. watch 监听

5.1 概述

watch 的作用和 vue2 中的作用相同,只不过在组合式 API 的情况下要写成函数的形式。

需要注意的是 Vue3 中的 watch 属性只能监视以下的 四种数据

  1. ref 定义的数据(实际上是其中的 value
  2. reactive 定义的数据
  3. 函数返回的一个值(getter 函数):主要是监视某一属性的时候使用
  4. 一个包含上述内容的数组

5.2 监视 ref 定义的基本数据类型

要点概览:

  1. 函数的返回值为 stopWatch
  2. 函数式写法

语法:

const stopWatch = watch(监视的参数, (newValue, oldValue)=> {
	console.log(newValue, oldValue);
	if (newValue >= 10) {
		stopWatch();
	}
})

注意我们 watch 中放的是响应式的数据,不需要加 .value ,通过我们之前提到的插件可以自动帮助我们添加。

返回的是一个 stopWatch 函数,我们可以通过这个函数来停止监视。

实践一下,监听一个 sum 打印出新的值,当其等于 10 的时候停止监视

<template>
  <div class="person">
    <h2>{{sum}}</h2>
  </div>
</template>

<script setup lang="ts">
import { ref, watch } from 'vue';
  let sum = ref(10);
  const stopWatch = watch(sum, (value)=> {
    console.log(value);
    if (value = 10) {
      stopWatch();
    }   
  })
</script>

5.3 监视 ref 定义的对象类型的数据

要点概览

  1. 监视的是对象的地址值
  2. 开启深度监视
  3. 对监视对象的理解

监视对象的时候我们监视的是这个对象的地址

<template>
  <div class="person">
    <h2>{{person.name}}</h2>
    <h2>{{person.age}}</h2>
    <button @click="changePerson"></button>
  </div>
</template>

<script setup lang="ts">
import { ref, watch } from 'vue';
  let person = ref({
    name: 'Tom',
    age: 18
  });
  const stopWatch = watch(person, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  })
  function changePerson () {
    person.value = {name: '李四', age: 19};
  }
</script>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

当对象修改的时候是可以检测到的,只是修改属性是无效的,但如果我们想要监听其中的属性,需要手动开启深度监视,向 watch 再传入一个配置对象来打开 深度监视

  const stopWatch = watch(person, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  }, {
      deep: true, immediate: true
  })

deep 是开启深度监视,immediate 是一进入界面立刻执行监视。

我们添加一个函数来修改 name,在把对象也打印出来:

  const stopWatch = watch(person, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  }, {deep: true, immediate: true})
  function changeName () {
    person.value.name = '李四';
  }

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

一看,为什么 newValueoldValue 是相同的呢?

这需要我们对于监听对象有更深入的了解,当对象修改的时候我们先去寻找 newValue 发现姓名被修改了,打印出整个对象出来,但是当我们再回头去寻找 oldValue 地址还是原来那个地址,所以打印出来的是修改后的值。

这是框架的一点小问题,无法通过技术手段避免,但我们开发的时候一般只用到 newValue 就能实现几乎所有的需求了,不需要去太关心这个,略作了解即可。

5.4 监视 reactive 定义的对象类型

要点概览:

  1. 自动开启深度监视

和上面相同,也是针对对象的监视,但需要注意的是对于 reactice 的监视,是默认开启深度监视的,而且我们无法关闭这个自动监视

对于这个设定其实很好理解,reactive 对象修改会失去响应式特性,我们不监视属性还能监视什么呢?🐶

<script setup lang="ts">
import { reactive, watch } from 'vue';
  let person = reactive({
    name: 'Tom',
    age: 18
  });
  const stopWatch = watch(person, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  }, {deep: true, immediate: true})
  function changePerson () {
    person = {name: '李四', age: 19};
  }
  function changeName () {
    person.name = '李四';
  }
</script>

写出代码,和上面没什么区别,注意一下 .value 和默认深度监视即可

5.5 监视响应式对象的某个属性

要点概览

  1. 属性值不是对象类型要写成函数形式
  2. 是对象类型也建议写成函数形式(一把梭)

我们也可以去监视响应式对象的某个属性,不需要将其转换为响应式数据(比如通过 toRef

所谓通过函数形式其实就是将需要监听的数据作为函数去传入,举个例子

<template>
  <div class="person">
    <h2>{{person.name}}</h2>
    <h2>{{person.age}}</h2>
    <button @click="changeName">changeName</button>
    <button @click="changeAge">changeAge</button>
  </div>
</template>

<script setup lang="ts">
import { reactive, watch } from 'vue';
  let person = reactive({
    name: 'Tom',
    age: 18
  });
  const stopWatch = watch(()=>person.name, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  })
  function changeAge () {
    person.age += 1
  }
  function changeName () {
    person.name = '李四';
  }
</script>

在上面的例子中,我们只监视 name 属性,Age 属性的改变不会被监视

const stopWatch = watch(()=>person.name, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
})

具体来看应该很清晰是如何传入特定的属性的

下面我们来看对象属性

let person = reactive({
    name: 'Tom',
    age: 18,
    friend: {
    	name: 'Jack'
    }
});
const stopWatch = watch(()=>person.name, (newValue, oldValue)=> {
    console.log(newValue, oldValue);
  })
function changeFriend() {
	person.friend = {name: '王五'}
}

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

是可以被监视到的

需要注意的是,对象属性其实不需要添加函数形式,正常写也是可以的,但为了格式的统一和记忆的方便,以后统一写成函数的形式,了解一下有不需要函数的写法即可

5.6 监视多种数据

要点概览:

  1. 掌握写法即可

因为非常好理解,这里直接给出写法,就是通过箭头函数返回多个值即可。

  watch([()=>person.name,person.car],(newValue,oldValue)=>{
    console.log('person.car变化了',newValue,oldValue)
  })

5.7 watchEffect

要点概览:

  1. watchEffect 的语法
  2. watch 的区别

在使用 watch 的时候,我们要手动的传入要监视的数据,但是在 watchEffect 中,会 自动识别 被监视的内容。

语法:

  const stopWatch = watchEffect(()=> {
    console.log(person.name);
  })

总结:

  • watchEffect适合于那些希望在函数内部自动追踪其依赖项的场景,当函数内部的响应式数据发生变化时,函数自动执行。
  • watch更适用于需要更精确地控制监视特定数据变化并执行相应操作的情况,可以监视特定数据或表达式,并在满足特定条件时执行回调函数。
  • 总的来说,watchEffectwatch都是用于侦听数据变化的方法,但watchEffect更自动化且适用于较为简单的场景,而watch提供了更多的控制能力,适用于需要更精确处理数据变化的情况。

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

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

相关文章

线程死锁检测组件逻辑与源码

死锁介绍 任务的执行体之间互相持有对方所需的资源而不释放&#xff0c;形成了相互制约而都无法继续执行任务的情况&#xff0c;被称为“死锁”。 死锁案例 线程A持有锁a不释放&#xff0c;需要去获取锁b才能继续执行任务&#xff0c; 线程B持有锁b不释放&#xff0c;需要去…

winform简易用户权限管理系统

一、功能简介 1. 数据库可使用sqlite、mssql、mysql等 2. 管理员账号不管控&#xff0c;其余账号进行权限管控&#xff08;左侧菜单&#xff0c;表单按钮&#xff09;&#xff0c;且只能看到自己创建的角色、用户 二、操作界面 1. 管理员账号登陆后&#xff0c;左侧菜单栏自动…

【Spark精讲】SparkSQL的RBO与CBO

Spark SQL核心:Catalyst Spark SQL的核心是Catalyst查询编译器&#xff0c;它将用户程序中的SQL/Dataset/DataFrame经过一系列操作&#xff0c;最终转化为Spark系统中执行的RDD。 Catalyst组成部分 Parser &#xff1a;用Antlr将SQL/Dataset/DataFrame转化成一棵未经解析的树…

怎么快速修复mfc140.dll文件?解决mfc140.dll缺失的方法

面对计算机报告的 ​mfc140.dll​ 文件遗失错误&#xff0c;这通常表明系统中缺少一个关键的动态链接库文件&#xff0c;该文件对于运行以 Microsoft Foundation Class (MFC) 库编写的程序十分重要&#xff0c;尤其是那些需要图形界面的应用程序和一些游戏。若没有这个文件&…

清风数学建模-数学规划模型

内容&#xff1a;数学规划模型&#xff08;cab aeqbeq lbub&#xff09; 一.题型类型 1.线性规划linprog 2.非线性规划 fmincon 3.整数规划 intlinprog 4.&#xff08;0-1规划&#xff09;&#xff08;特殊的线性整数规划&#xff09;intlinprog 5.多目标规划 linprog 标…

JumpServer3.0版本(用户管理、邮件、MFA认证配置)

创建用户组 控制台页面可以看见左侧的用户管理下,有用户列表和用户组 点击用户组、点击创建按钮、设置名称,用户不用选择还没建用户,提交即可 创建用户 点击用户列表创建按钮,设置名称、用户名、邮箱等必填项 这个时候用户组选项,可以选好我们创建的用户组了,先创用…

Spring高手之路-Spring Bean、Java Bean和对象的区别与联系

目录 什么是Spring Bean 什么是Java Bean 什么是对象 Spring Bean与Java Bean与对象的联系与区别 联系 区别 什么是Spring Bean 在Spring官方文档中对Bean的解释如下&#xff1a; In Spring, the objects that form the backbone of your application and that are manage…

MySQL数据库高级SQL语句及存储过程

目录 一、高级SQL语句 &#xff08;一&#xff09;case语句 1.语法定义 2.示例 &#xff08;二&#xff09;空值(NULL) 和 无值( ) 1.区别 2.示例 &#xff08;1&#xff09;字符长度 &#xff08;2&#xff09;判断方法 ① 空值(NULL) ② 无值( ) &#xff08;3…

代码随想录算法训练DAY18|二叉树5

算法训练DAY18|二叉树5 513.找树左下角的值 力扣题目链接 给定一个二叉树&#xff0c;在树的最后一行找到最左边的值。 示例 1: 示例 2: 思路 本题要找出树的最后一行的最左边的值。此时大家应该想起用层序遍历是非常简单的了&#xff0c;反而用递归的话会比较难一点。 我…

【通关喜报】腾讯云TDSQL TCP/TCE、云运维tcp 12月认证考试,全员过关,年终冲刺!

2023年12月23日云贝教育有6位学员参加了腾讯云TDSQL-TCP以及TCE认证考试。都取得非常好的成绩~下面我们来看一下各位同学的理论考试和上机考试成绩吧~

BWP频域位置的确定

这里根据协议整理下BWP频域相关参数以及如何确定BWP的频域位置。 BWP的配置包含几个参数 &#xff1a; 1 SCS, CyclePrefix 和locationAndBandwidth。 BWP频域起始位置N_start_BWPOcarrierRBstart&#xff0c;其中Ocarrier 由RRC层参数offsetToCarrier决定。 locationAndB…

Java学习——设计模式——结构型模式2

结构型模式 结构型模式主要涉及如何组合各种对象以便获得更好、更灵活的结构。虽然面向对象的继承机制提供了最基本的子类扩展父类的功能&#xff0c;但结构型模式不仅仅简单地使用继承&#xff0c;而更多地通过组合与运行期的动态组合来实现更灵活的功能。 包括&#xff1a; 1…

Redis命令---String篇 (超全)

目录 1.Redis Setnx 命令 - 只有在 key 不存在时设置 key 的值。简介语法可用版本: > 1.0.0返回值: 设置成功&#xff0c;返回 1 。 设置失败&#xff0c;返回 0 。 示例 2.Redis Getrange 命令 - 返回 key 中字符串值的子字符简介语法可用版本: > 2.4.0返回值: 截取得到…

vue3 接入 Element Plus

vue3 接入 Element Plus vue3 发布已经很久了&#xff0c;官方也已经发布公告&#xff0c;自2023年12月31日起停止对 vue2 版本的维护更新&#xff0c;因此&#xff0c;vue3 正式登上了历史的舞台。组件库一直是前端开发的利器&#xff0c;减少了开发者开发复杂度&#xff0c;提…

计算机毕业设计------基于SpringCloud的实验室管理系统

项目介绍 实验室管理系统的用户可以分为两种&#xff1a;系统管理员和普通用户。系统管理员主要功能&#xff1a; 登录登出、分析数据、管理用户、管理日志、管理实验室、管理预约、维护个人资料、实验室保修管理 用户主要功能&#xff1a; 注册登录、查询实验室、实验室预约…

Edge浏览器的卸载(一分钟版)

一分钟看完不耽误 开整工具下载后 结尾 开整 工具 Remove-MS-Edge 看名字&#xff0c;简单直接 CSDN下载 资源设置是免费的&#xff0c;大家尽管下载 不放心软件安全的话&#xff0c;自己上github地址下载也行 下载后 解压之后 我们打开有gui的&#xff0c;也就是有界面的&…

胡润研究院发布《2023胡润中国最具历史文化底蕴品牌榜》

胡润研究院发布《2023胡润中国最具历史文化底蕴品牌榜》&#xff0c;前十名分别是片仔癀、同仁堂、贵州茅台、五粮液、中国银行、中华、黄山、农业银行、建设银行、汾酒。 榜单调研范围涵盖中国内地具有60年以上历史的为消费者提供产品或服务的品牌&#xff0c;综合考察品牌历史…

polar CTF web upload tutu

一、题目 二、解题 1、上传两个一样的木马提示不是 setu&#xff08;色图&#xff09; 2、上传两个图&#xff0c;提示md5值不一样 综上他需要两张md5值相同的图 找工具 fastcoll 可生成两个md5值相同的文件 http://www.win.tue.nl/hashclash/fastcoll_v1.0.0.5.exe.zip 照…

编织Spring魔法:解读核心容器中的Beans机制【beans 一】

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 编织Spring魔法&#xff1a;解读核心容器中的Beans机制【beans 一】 前言什么是Spring核心容器Beans的生命周期管理&#xff1a;初始化和销毁方法&#xff1a;各种作用域&#xff1a; beans的配置方式…

【Bidomain建模范式:Pansharpening】

Bidomain Modeling Paradigm for Pansharpening &#xff08;泛锐化的Bidomain建模范式&#xff09; 泛锐化是一个具有挑战性的低层次视觉任务&#xff0c;其目的是学习光谱信息和空间细节之间的互补表示。尽管取得了显着的进步&#xff0c;现有的基于深度神经网络&#xff0…