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

很激动进入了 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.hqwc.cn/news/317042.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《低功耗方法学》翻译——卷首语

就目前半导体的发展现状来说&#xff0c;我们国家还处在奋力追赶阶段。在我国半导体行业历经多轮技术制裁的今天&#xff0c;我们不得不承认的是&#xff0c;半导体技术最先进的就是美国。我国早在上世纪六七十年代就有涉足半导体技术&#xff0c;大量华裔留美的爱国人士回国为…

清风数学建模笔记-因子分析

内容&#xff1a;因子分析 概念&#xff1a; 通过分析研究变量间的相关系数矩阵&#xff0c;把这些变量间错综复杂的关系归结成少数几个综合因子&#xff0c;由于归结出的因子个数少于原始变量的个数&#xff0c;但是又包含原始变量的信息&#xff0c;所以这一过程也称之为降…

Django Web框架

1、创建PyCharm项目 2、安装框架 pip install django4.2.0 3、查看安装的包列表 4、使用命令创建django项目 django-admin startproject web 5、目录结构 6、运行 cd web python manage.py runserver7、初始化后台登录的用户名密码 执行数据库迁移生成数据表 python man…

Objects are not valid as a React child (found: object with keys {name}).

在jsx中可以嵌套表达式&#xff0c;将表达式作为内容的一部分&#xff0c;但是要注意&#xff0c;普通对象不能作为子元素&#xff1b;但是数组&#xff0c;react元素对象是可以的 如下&#xff1a;不能将stu这个对象作为子元素放 function App() {const myCal imgStyleconst…

sentinel控制面板dashboard的下载安装教程

目录 一、dashboard控制面板下载二、启动dashboard 一、dashboard控制面板下载 资源下载地址: https://github.com/alibaba/Sentinel/releases 也可以点击这里进行下载&#xff0c;无需积分 找到需要下载的版本&#xff0c;展开下面的资源Assets&#xff0c;下载sentinel-das…

NSSCTF Http pro max plus

开启环境: 进去显示只允许本地访问,打开bp: 请求头写 x-forwarded-for: 127.0.0.1 换一种 client-ip: 127.0.0.1 执行显示 You are not from pornhub.com ! 请求头写 referer: pornhub.com 执行显示 不开代理你想上p站&#xff1f; 代理服务器地址是Clash.win ,请求头写 via: …

手把手教你学会接口自动化框架的搭建-前言

在网上看过很多帖子,各种接口自动化的框架眼花缭乱,但是对于很多才做自动化的新手,那是一头雾水。 因此,我决定出一个系列,让你能够按照我的文档一步步把接口自动化都做起来,而不是网上这种一股脑的全部抛出,让你看的云里雾里的。 看完这些文档保证你能去任何一家公司,…

BWP频域位置的确定

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

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

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

BIO和NIO编程(待完善)

目录 IO模型 BIO NIO 常见问题 IO模型 Java共支持3种网络编程IO模式&#xff1a;BIO&#xff0c;NIO&#xff0c;AIO BIO 同步阻塞模型&#xff0c;一个客户端连接对应一个处理线程 代码示例&#xff1a; Server端&#xff1a; public class BioServer {private static …

学到了!3步get微信自动回复

你是不是也有过这样的烦恼&#xff1a;因为忙碌或是消息太多&#xff0c;没能及时回复好友消息&#xff0c;尤其是在休息、节假日的时候。 今天就给大家种草一款能够让微信自动回复消息的神器——微信管理系统&#xff0c;让你再忙碌也能及时回复好友&#xff01;而且操作也不…

通过智能钱包监控降低加密交易费用

作者&#xff1a;stellafootprint.network 随着加密货币的普及&#xff0c;交易费用已成为一个不容忽视的问题。网络拥堵和 Gas 费的价格战&#xff0c;导致交易费用波动&#xff0c;严重影响了用户的预算。但是&#xff0c;通过智能钱包监控&#xff0c;我们可以有效降低交易…