Vue 3.5 新特性解析

在Vue 3.5中,几个新特性值得关注,它们将极大简化和增强你的开发体验。让我们逐一深入了解这些特性。

1. defineProps支持解构

在Vue 3.5中,defineProps现在支持解构。你可以直接从defineProps中解构出需要的属性,而不必像以前一样使用props.xxx。例如:

const { age = 0, name = '张三' } = defineProps<{age?: number;name?: string;
}>();const test = () => {console.log('----->', name, age);
}

这样可以简化代码,并使其更加清晰。然而,对于不常使用setup语法糖的开发者来说,这一变化可能影响不大。

2. useTemplateRef - 定义模板的 DOM 元素的 ref

useTemplateRef是一个新引入的 API,它使得定义模板中的 DOM 元素的 ref 更加直观和简洁。使用示例如下:

<script setup>
import { useTemplateRef, onMounted } from 'vue'const inputRef = useTemplateRef('inputRef')onMounted(() => {inputRef.value.focus()
})
</script><template><input ref="inputRef" />
</template>

这个新 API 解决了以前使用 ref() 声明 DOM 元素时的混淆问题,使得代码更具可读性。

3. useId - 获取唯一的 Vue 实例 ID

useId 提供了一个生成唯一 ID 的简单方式,对于表单元素和动态组件的渲染非常有用:

<script setup>
import { useId } from 'vue'const id = useId()
</script><template><form><label :for="id">Name:</label><input :id="id" type="text" /></form>
</template>

这一特性有助于确保 ID 的唯一性,避免了手动管理 ID 的麻烦。

4. watchdeep 支持数字

watch 现在允许在 deep 属性中传入数字,指定监听响应性数据的层级。这对于细化数据监听非常有用:

const testData = reactive({a: {b: {c: {d: 1}}}
})watch(() => testData, () => {console.log('state changed')},{ deep: 2 }
);testData.a.b = { c: { d: 2 } } // 触发监听
testData.a.b.c = { d: 3 } // 不触发

这种方式能精确控制监听的深度,提高性能和控制力。

5. onWatcherCleanup - 清除副作用

onWatcherCleanup 允许在 watch 函数中注册清理副作用的操作:

import { watch, onWatcherCleanup } from 'vue'watch(id, (newId) => {const { response, cancel } = doAsyncWork(newId)onWatcherCleanup(cancel)
})watch(id, (newId, oldId, onCleanup) => {const { response, cancel } = doAsyncWork(newId)onCleanup(cancel);
})

在组件卸载之前或者下一次 watch 回调执行之前会自动调用 onWatcherCleanup 函数,同样有了这个函数后你就不需要在组件的 beforeUnmount 钩子函数去统一清理一些 timer 了

这使得处理异步操作和清理副作用变得更加简便。

6. defineModel - 简化 v-model 实现

虽然 defineModel 是 Vue 3.4 中的功能,但它简化了 v-model 的实现,值得记住。更多信息可以参考 Vue 官方文档:defineModel。

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

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

相关文章

纯态和非纯态的理解(望指正)

纯态和非纯态的理解 量子状态的系统密度算子的特征量子态纯态混合态 纯态判别混合态判别 量子状态的系统 假设一个量子系统以概率 p i p_i pi​处于多个状态 ∣ ψ i ⟩ |\psi_i\rangle ∣ψi​⟩之一. 我们把 { p i , ∣ ψ ⟩ } \{p_i,|\psi\rangle\} {pi​,∣ψ⟩}称为一个…

Python中字典推导式(Dict Comprehension)是如何工作的

Python中的字典推导式&#xff08;Dict Comprehension&#xff09;是一种简洁而强大的构造字典的方式。它允许你从现有的可迭代对象&#xff08;如列表、元组、集合或另一个字典&#xff09;中快速生成新的字典&#xff0c;通过对元素应用一个表达式来设置键和值。字典推导式不…

Android Home应用程序启动流程

Android系统在启动时安装应用程序的过程&#xff0c;这些应用程序安装好之后&#xff0c;还需要有一个Home应用程序来负责把它们在桌面上展示出来&#xff0c;在Android系统中&#xff0c;这个默认的Home应用程序就是Launcher了&#xff0c;本文将详细分析Launcher应用程序的启…

构建现代API:FastAPI中Query与Body参数的最佳搭配

在FastAPI中&#xff0c;Query 和 Body 是两种不同的依赖注入器&#xff0c;它们的应用场景取决于你的具体需求。以下是它们各自常见的使用场景&#xff1a; Query 参数 使用场景&#xff1a; 当你需要从URL中获取一些简单的参数时&#xff0c;例如过滤、排序、分页等。 当数…

李宏毅机器学习笔记——反向传播算法

反向传播算法 反向传播&#xff08;Backpropagation&#xff09;是一种用于训练人工神经网络的算法&#xff0c;它通过计算损失函数相对于网络中每个参数的梯度来更新这些参数&#xff0c;从而最小化损失函数。反向传播是深度学习中最重要的算法之一&#xff0c;通常与梯度下降…

java上一页下一页的代码怎么写

在Java中实现“上一页”和“下一页”功能的代码&#xff0c;通常用于分页的情况&#xff0c;比如从数据库查询数据并分页显示结果。假设你有一个列表&#xff0c;想要通过“上一页”和“下一页”按钮来翻页&#xff0c;可以使用以下代码作为参考。 假设我们有一个数据列表&…

软考基础知识之计算机网络

目录 前言 网络架构与协议 网络互联模型 1、OSI/RM 各层的功能 2、TCP/IP 结构模型 常见的网络协议 1、应用层协议 2、传输层协议 3、网络层协议 IPv6 前言 从古代的驿站、 八百里快马&#xff0c; 到近代的电报、 电话&#xff0c; 人类对于通信的追求从未间断&…

Docker 镜像配置

在 Docker 的使用过程中&#xff0c;拉取镜像是一个常见的操作&#xff0c;但在国内由于网络问题&#xff0c;直接从 Docker Hub 拉取镜像可能会比较慢。为了解决这个问题&#xff0c;我们可以配置 Docker 使用国内镜像源&#xff0c;从而加速镜像的拉取过程。本文将介绍如何配…

心觉:你为什么没有更多的钱

很多人希望自己可以赚更多的钱 但是他的内心又很讨厌钱&#xff0c;他自己并不知道 一边希望自己赚更多钱&#xff0c;一边在骨子里觉得“金钱是万恶之源” 这是一种神经质的错乱 这种现象在什么情况下会表现得比较明显呢&#xff1f; 某位高官因为贪污受贿落马了&#xf…

风控系统之指标回溯,历史数据重跑

个人博客&#xff1a;无奈何杨&#xff08;wnhyang&#xff09; 个人语雀&#xff1a;wnhyang 共享语雀&#xff1a;在线知识共享 Github&#xff1a;wnhyang - Overview 回顾 默认你已经看过之前那篇风控系统指标计算/特征提取分析与实现01&#xff0c;Redis、Zset、模版方…

前端基础面试题·第三篇——JavaScript(其一)

1.JavaScript数据类型与运算符 数据类型 原始数据类型&#xff1a; 1.Number 2.String 3.Boolean 4.undefined 5.null 6.Symbol 7.bigint 复杂数据类型&#xff1a; 1.Function 2.非函数&#xff1a; Array: 数组 Object: 对象 Date: 日期 RegExp: 正则 Map: 映射 Set: 集合 …

word中怎么快速选中光标之前或之后的全部内容?

在Word中&#xff0c;快速选中光标之后的全部内容的快捷键&#xff1a;Ctrl Shift End&#xff1b; 在Word中&#xff0c;快速选中光标之前的全部内容的快捷键&#xff1a;Ctrl Shift Home。 在Word中&#xff0c;选取的快捷键如下。 一、选定整个文本&#xff1a; 1&#…

Cozer必备!一站式解锁扣子全网最全插件集锦(五)

俗话说&#xff0c;工欲善其事必先利其器&#xff01; 用过Coze的朋友都知道&#xff0c;插件在Coze里的重要性。插件库就相当于武器库&#xff0c;一个好的插件&#xff0c;就相当于一件趁手的兵器&#xff0c;可以让你事半功倍&#xff01; 程哥精心整理了Coze最常用和好用…

spring cloud openFeign

1:Intellij 新建 项目 order-service 2:pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&q…

golang学习笔记02——gin框架及基本原理

目录 1.前言2.必要的知识3.路由注册流程3.1 核心数据结构3.2 执行流程3.3 创建并初始化gin.Engine3.4 注册middleware3.5 注册路由及处理函数&#xff08;1&#xff09;拼接完整的路径参数&#xff08;2&#xff09;组合处理函数链&#xff08;3&#xff09;注册完成路径及处理…

精通Java微服务

第1章 微服务是在面向服务架构SOA的基础上进一步发展而来的&#xff0c;它比SOA做得更加彻底&#xff0c;其单体服务被更加彻底地划分&#xff0c;最大限度地实现了服务的单一职责。 1.1.2互联网 即计算机网络&#xff0c;连接了世界上数以万计的计算机设备&#xff08;可联…

15、Django Admin添加自定义字段功能

修改模型类HeroAdmin admin.register(Hero) class HeroAdmin(admin.ModelAdmin):change_list_template "entities/heroes_changelist.html"... # 此处原代码不动&#xff0c;只增加此前后代码def get_urls(self):urls super().get_urls()my_urls [path(immort…

最新版 | SpringBoot3如何自定义starter(面试常考)

文章目录 一、自定义starter介绍二、自定义Starter的好处及优势三、自定义starter应用场景四、自定义starter1、创建autoconfigure的maven工程2、创建starter的maven工程3、在autoconfigure的pom文件中引入MyBatis的所需依赖4、编写自动配置类MyBatisAutoConfiguration5、编写i…

pdf文件编辑器有哪些?分享适合新手用的5个PDF编辑器(解锁教程)

pdf是一种通用文件格式&#xff0c;也是一种夸操作系统平台的文件格式。 好用的PDF文件编辑器可以让您更改和添加文本、编辑图像、添加图形、签署签名、填写表单数据等。下面整理了关于pdf文件编辑方法介绍&#xff0c;以及一些好用的pdf编辑器&#xff0c;有需要的可以了解下…

JavaScript初级——Navigatior

1、Navigator 代表当前浏览器的信息&#xff0c;通过该对象可以来识别不同的浏览器。 2、由于历史原因&#xff0c;Navigator 对象中的大部分属性已经不能帮助我们是被浏览器了。 3、一般使用 userAgent 来判断浏览器的信息。 4、 userAgent 是一个字符串&#xff0c;包含有用来…