【Vue3】watch 监视 ref 定义的数据

【Vue3】watch 监视 ref 定义的数据

  • 背景
  • 简介
  • 开发环境
  • 开发步骤及源码
  • 参数说明

背景

随着年龄的增长,很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来,技术出身的人总是很难放下一些执念,遂将这些知识整理成文,以纪念曾经努力学习奋斗的日子。本文内容并非完全原创,大多是参考其他文章资料整理所得,感谢每位技术人的开源精神。

简介

本文介绍 Vue3 中如何使用 watch 函数监视 ref 定义的数据。

开发环境

分类名称版本
操作系统WindowsWindows 11
IDEVisual Studio Code1.91.1

开发步骤及源码

1> 创建 Vue3 工程,参考:【Vue3】工程创建及目录说明。

2> 删除 src 目录下 assetscomponents 目录。

3> 修改 src 目录下 main.ts

import { createApp } from 'vue'
import App from './App.vue'createApp(App).mount('#app')

4> 重写 Vue 根组件 App.vue,监视 ref 定义的基本类型数据。

<template><div class="person"><h1>监视 ref 定义的基本类型数据</h1><h2>姓名:{{ name }}</h2><h2>年龄:{{ age }}</h2><button @click="growUp">长大</button></div>
</template><script setup lang="ts" name="App">
import { ref, watch } from 'vue'const name = ref('Harry Potter')
const age = ref(10)function growUp() {age.value += 1
}// 监视
const stopWatch = watch(age, (newValue, oldValue) => {console.log('%s 又长大一岁,从 %d 岁到 %d 岁', name.value, oldValue, newValue)if (newValue >= 18) {console.log('%s 成人了,可以不用再监护了', name.value)stopWatch()}
})
</script><style scoped></style>

5> 执行 npm run dev 命令启动应用,浏览器访问 http://localhost:5173/,点击页面中 长大 功能按钮,观察日志打印。
监视日志-ref定义的基本类型数据

6> 重写 Vue 根组件 App.vue,监视 ref 定义的对象类型数据。

<template><div class="person"><h1>监视 ref 定义的对象类型数据</h1><h2>姓名:{{ person.name }}</h2><h2>年龄:{{ person.age }}</h2><button @click="growUp">长大</button><button @click="replace">换人</button></div>
</template><script setup lang="ts" name="App">
import { ref, watch } from 'vue'const person = ref({name: 'Harry Potter',age: 10,
})function growUp() {person.value.age += 1
}function replace() {person.value = {name: '赫敏·格兰杰',age: 11,}
}// 监视
const stopWatch = watch(person, (newValue, oldValue) => {console.log('人员信息变更,从 %o 变成 %o', oldValue, newValue)if (newValue.age >= 18) {console.log('%s 成人了,可以不用再监护了', person.value.name)stopWatch()}
}, {deep: true
})
</script><style scoped></style>

7> 执行 npm run dev 命令启动应用,浏览器访问 http://localhost:5173/,点击页面中 长大换人 功能按钮,观察日志打印。
监视日志-ref定义的对象类型数据

参数说明

watch 函数参数包括:

  • 参数一:监视的数据源,本示例中是 ref 定义的基本类型或对象类型数据。
  • 参数二:监视的数据源发生变化时触发的回调函数,此回调函数含 2 个参数:
    • 参数一:监视数据源变化后的新值。
    • 参数二:监视数据源变化前的旧值。
  • 参数三:监视配置对象,包括:
    • deep: true:开启深度监视,监视 ref 定义的对象类型数据时,只有开启了深度监视,才能在对象属性发生变化时触发回调。
    • immediate: truewatch 默认是懒执行的,仅当数据源变化时才会执行回调,使用此配置可以在创建监视器时立即执行一次回调。
    • once: truewatch 默认是每次数据源变化都会触发回调函数的执行,使用此配置在数据源变化时仅触发一次。

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

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

相关文章

基于STM32的逻辑分析仪

文章目录 一、逻辑分析仪体验1、使用示例1.1 逻辑分析仪1.2 开源软件PulseView 2、核心技术2.1 技术方案2.2 信号采集与存储2.3 数据上传 3、使用逻辑分析仪4、 SourceInsight 使用技巧4.1新建工程4.2 设置工程名及工程数据目录4.3 指定源码目录4.4 添加源码4.5 同步文件4.6 操…

string使用及模拟

前言 相信看过我博客的小伙伴都已经C的接触已经很久了&#xff0c;也没那么多废话。stl库直接走起&#xff0c;最开始、最简单的就是string。string就相当于是把C语言中的字符串“char[]”给升了级&#xff0c;像是顺序表一样多了记录长度和容量的大小&#xff0c;还加了很多的…

大模型面试:LLM+向量库的文档对话系统

面试题 1.1 为什么大模型需要外挂(向量)知识库&#xff1f;如何将外部知识注入大模型&#xff0c;最直接的方法&#xff1a;利用外部知识对大模型进行微调 回答 大模型需要外挂(向量)知识库的原因&#xff1a; 知识更新频率&#xff1a;大模型在训练时使用的知识是静态的&am…

免杀笔记 -->API的整理Shellcode加密(过DeFender)

最近更新频率明显下降我懒&#xff0c;那么今天就来记录一下我们的一些常用的API的整理以及ShellCode的加密。 1.WinAPI整理 问我为什么要整理&#xff1f; 就是用起来的时候要左翻右翻 &#xff1a;&#xff1a; 烦死了 1.VirtualAlloc VirtualAlloc(NULL,sizeof(buf),MEM_…

人工智能和计算机视觉领域国际学术会议submission

文章目录 1. AAAI 20252. CVPR 20253. ICCV 20254. IJCAI 20255. ICRA 20256. NeurIPS 20257. ACL 20258. ICLR 2025 1. AAAI 2025 人工智能促进协会&#xff08;AAAI&#xff09;是一个成立于1979年的非营利性科学组织&#xff0c;专注于深化对智能行为和思维机制的科学理解&…

通过 WSL 2 在Windows 上挂载 Linux 磁盘

原文查看 曾为了传输或者共享不同系统的文件频繁地在 Windows 和 Linux 系统之间切换&#xff0c;效率过低&#xff0c;所以尝试通过 WSL 2 在Windows 上挂载 Linux 磁盘。 先决条件 需要在Windows 10 2004 及更高版本&#xff08;Build 19041 及更高版本&#xff09;或 Win…

排查一次线程泄漏

背景&#xff1a;最近经常发生K8S健康检查到应用的心跳接口超时不通&#xff0c;然后发生了重启&#xff0c;第一时间进入pod内部使用任何jvm命令都会导致java进程重启&#xff08;也包括arthas工具使用不了&#xff09;&#xff0c;dump不下来&#xff0c;事故现场没法保留&am…

SpringBoot集成Sharding-JDBC实现分库分表

本文已收录于专栏 《中间件合集》 目录 版本介绍背景介绍拆分方式集成并测试1.引入依赖2.创建库和表3.pom文件配置3.编写测试类Entity层Mapper接口MapperXML文件测试类 4.运行结果 自定义分片规则定义分片类编写pom文件 总结提升 版本介绍 SpringBoot的版本是&#xff1a; 2.3.…

电子期刊制作攻略:从零开始,轻松入门

​随着互联网的快速发展&#xff0c;电子期刊已经逐渐成为人们获取信息和娱乐的重要途径。越来越多的人开始关注并投身于电子期刊的制作行业。那么&#xff0c;如何从零开始&#xff0c;轻松入门电子期刊制作呢&#xff1f; 1.首先点击FLBOOK在线制作制作电子杂志平台 2.点击开…

【odoo17】后端py方法触发右上角提示组件

概要 在前面文章中&#xff0c;有介绍过前端触发的通知服务。 【odoo】右上角的提示&#xff08;通知服务&#xff09; 此文章则介绍后端触发方法。 内容 直接上代码&#xff1a;但是前提一定是按钮触发&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; def bu…

无法解析插件 org.apache.maven.plugins:maven-war-plugin:3.2.3(已解决)

文章目录 1、问题出现的背景2、解决方法 1、问题出现的背景 最开始我想把springboot项目转为javaweb项目&#xff0c;然后我点击下面这个插件 就转为javaweb项目了&#xff0c;但是我后悔了&#xff0c;想要还原成springboot项目&#xff0c;点开项目结构关于web的都移除了&am…

HarmonyOS Next 省市区级联(三级联动)筛选框

效果图 完整代码 实例对象 export class ProvinceBean {id?: stringpid?: stringisSelect?: booleandeep?: objectextName?: stringchildren?: ProvinceBean[] }级联代码 import { MMKV } from tencent/mmkv/src/main/ets/utils/MMKV import { ProvinceBean } from ..…

【Git】merge合并分支

两个分支未修改同一个文件的同一处位置: Git自动合并 两个分支修改了同一个文件的同一处位置:产生冲突 例&#xff1a; 在master分支修改了main同时&#xff0c;feat分支也修改了相同的文件 合并的时候就会产生冲突 解决方法: Step1- 手工修改冲突文件&#xff0c;合并冲突内容…

【数据结构】单链表的增删改查

介绍 链表是有序的列表&#xff0c;但是它在内存中是如下存储的&#xff1a; ①链表以节点的方式进行存储&#xff0c;是链式存储的 ②每个节点包含 data 域、next 域&#xff1a;指向下一节点 ③链表的各个节点不一定是连续存放的 ④链表分为有头节点的链表和没有头节点的链表…

比肩 GPT-4o 的 Llama 3.1 本地部署快速体验的方法

比肩 GPT-4o 的 Llama 3.1 本地部署快速体验的方法 flyfish Llama 3.1模型简介 Llama 3.1是一系列大型语言模型&#xff0c;包含以下几种规模&#xff1a; 8B 参数&#xff1a;模型中有80亿个参数 70B 参数&#xff1a;模型中有700亿个参数 405B 参数&#xff1a;模型中有4…

深入理解MySQL锁机制与性能优化:详解记录锁、间隙锁、临键锁及慢SQL查询分析

1. 事务隔离和锁机制详解 记录锁 第一种情况,当我们对于唯一性的索引(包括唯一索引和主键索引)使用等值查询,精准匹配到一条记录的时候,这个时候使用的就是记录锁。 比如 where id = 1 4 7 10。 间隙锁 第二种情况,当我们查询的记录不存在,无论是用等值查询还是范围…

【vue教程】四. Vue 计算属性和侦听器

目录 本章涵盖知识点回顾计算属性&#xff08;Computed&#xff09;创建计算属性计算属性的多样性计算属性的数组过滤计算属性的复杂表达式 计算属性 vs 方法计算属性的实例演示 侦听器&#xff08;Watchers&#xff09;创建侦听器侦听器的高级用法侦听器的深度观察侦听器的立即…

无线遥控控制直流电机和无刷电机开关

一 目的 此文章记录了arduino与陶晶驰串口屏实现联动&#xff0c;点击屏幕双态开关远程控制arduino2560板载的直流电机和无刷电机开关。为手搓乒乓球发球机做准备。 二 接线 2.1串口屏接线 串口屏与Arduino UNO接线如下&#xff1a; ———————————————— RX …

pdf2image:将PDF文档转化为图像的Python魔法

标题&#xff1a;探索pdf2image&#xff1a;将PDF文档转化为图 像的Python魔法 背景 在数字时代&#xff0c;我们经常需要处理各种格式的文档&#xff0c;尤其是PDF文件。PDF以其跨平台的可读性和稳定性而广受欢迎。然而&#xff0c;有时我们需要将PDF文件转换成图像格式&am…

C++ - char*、const char*、char[]、string

const char* const char* 用来定义字符串常量。 char[ ] char型的字符数组是一种定长的数组&#xff0c;存储指定长度的字符序列&#xff0c;数组中的每个元素都是一个char类型的变量&#xff0c;如&#xff1a; char arr[] {h, a, l, l, o, \0}; char c arr[0]; // 访问…