Vue3新特性全预览

news2025/1/10 6:13:17

目录

自定义Hook函数

介绍

示例

toRef和toRefs

介绍

代码示例

 shallowReactive和shallowRef(不常用只做了解)

 readonly与shallowReadonly(不常用只做了解)

 toRaw与markRaw(不太常用只做了解)

 provide与inject

介绍

代码示例

​编辑 响应式数据的判断

Composition Api的优势 

Optins Api存在的问题

新的组件

Fragment

Teleport

Suspense

 拓展


自定义Hook函数

介绍

hook本质是一个函数 把setup函数中使用的Composition Api进行了封装

类似于Vue2.x中的mixin

优势: 可复用代码 让setup中的逻辑更清晰

示例

获取鼠标点击的位置坐标

 传统书写函数方法在setup中书写

测试

现在的业务场景就是如果其他组件也需要使用到该功能的话就需要再书写一遍,所以这里就可以将该功能封装成自定义的hook

新建hook文件夹,并创建js文件,将刚才在setup中书写的逻辑代码封装在这个js文件中 

导入hook文件使用,hook文件中已经将最后的数据进行返回,所以这里导入文件后可以直接使用数据来接该数据 

 测试效果和前面效果一致,不再展示

toRef和toRefs

介绍

创建一个ref对象 其value值指向另一个对象中的某个属性值

语法: const 变量名 = toRef(数据对象,'对象属性')

应用场景: 要将响应式对象中的某个属性单独提供给外部使用时

toRefs和toRef功能一致 但可以批量创建多个ref对象 语法: toRefs(数据对象)

概念太过抽象,下面还是代码中见真章

代码示例

测试:

上面例子只是一个简单的reactive数据绑定

如果在绑定的标签渲染中不想再使用per.这种形式,就需要用到toRef的方式

测试效果一致

还有一种有坑的写法:

  在暴露数据时直接ref数据

 注意观察,其下面的数据进行变动时源数据并没有发生变化,导致修改的数据和源数据分家了,在使用时酌情处理

在对象数据属性太多时就可以使用toRefs进行批量处理: 

 

 注意toRefs在解构对象类型数据时只能解构一层,如果是多层嵌套,还是需要在标签渲染时多层书写

 shallowReactive和shallowRef(不常用只做了解)

 readonly与shallowReadonly(不常用只做了解)

 toRaw与markRaw(不太常用只做了解)

 provide与inject

介绍

作用:实现父级组件和后代组件间通信

用法: 父组件有一个provide选项来提供数据 子组件有一个inject选项来使用这些数据

代码示例

准备 父(App)->子(Child)->孙(Son)三个组件

父组件:

父组件定义数据传递给后代组件

 son组件接收父级组件传递的数据,直接跳过child组件

效果:

 响应式数据的判断

 

Composition Api的优势 

可以更加优雅的组织代码 函数 让相关功能的代码更加有序的组织在一起

Optins Api存在的问题

使用传统OptionsApi中 新增或者修改一个需求 就需要分别在data methods computed里进行修改

新的组件

Fragment

在vue2中 组件必须有一个根标签

在vue3中 组件可以没有根标签 内部会将多个标签包含在一个Fragment虚拟元素中

优点: 减少标签层级 减少内存占用

Teleport

Teleport是一种能够将组件html结构移动到指定位置的技术

Suspense

等待异步组件时渲染一些额外内容 让应用有更改的用户体验

 拓展

 

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

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

相关文章

QML Canvas 元素(渐变和阴影)

作者: 一去、二三里 个人微信号: iwaleon 微信公众号: 高效程序员 经过前面的 Canvas 学习,我们可以很容易地使用 strokeStyle 和 fillStyle 来设置图形的边框色和填充色,例如:“green”、“black” 等。其实除了使用纯色之外,我们还可以使用一些渐变色,如果你想让图形…

基于matlab使用卡尔曼滤波器进行对象跟踪(附源码)

一、前言 此示例演示如何使用对象和函数来跟踪对象。 二、介绍 卡尔曼滤波器有许多用途,包括控制、导航、计算机视觉和时间序列计量经济学方面的应用。此示例说明了如何使用卡尔曼滤波器跟踪对象,并重点介绍三个重要功能: 预测物体的未来位置…

基于条件风险价值CVaR的微网动态定价与调度策略(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

人工智能(pytorch)搭建模型14-pytorch搭建Siamese Network模型(孪生网络),实现模型的训练与预测

大家好,我是微学AI,今天给大家介绍一下人工智能(pytorch)搭建模型14-pytorch搭建Siamese Network模型(孪生网络),实现模型的训练与预测。孪生网络是一种用于度量学习(Metric Learning)和比较学习(Compariso…

教学实训模块升级,助力应用型数据科学人才培养|ModelWhale 版本更新

初夏梅雨季,ModelWhale 迎来新一轮版本更新,多角度优化各领域用户的使用体验。 本次更新中,ModelWhale 主要进行了以下功能迭代: • 优化 课程作业布置(团队版✓ ) • 新增 课程作业关联至课件&#xff…

MySQL的服务层和存储引擎层

1. 服务层(Server Layer): 服务层是MySQL的顶层组件,负责处理客户端与MySQL服务器之间的交互。它提供了一组API和协议,使应用程序能够连接到MySQL服务器,并发送查询、事务管理、用户权限控制等请求。服务层…

6-js基础-1

JavaScript 基础 - 1 了解变量、数据类型、运算符等基础概念,能够实现数据类型的转换,结合四则运算体会如何编程。 JavaScript介绍变量常量数据类型运算符实战案例 重点单词: js介绍 能说出JavaScript 是什么? 怎么写? 能写出JavaScript 输…

【C++详解】——红黑树

目录 红黑树的概念 红黑树的性质 红黑树节点的定义 红黑树的结构 红黑树的插入操作 情况一 情况二 情况三 红黑树的验证 红黑树的查找 红黑树与AVL树的比较 红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上增加一个存储位表示…

基于SpringBoot的在线拍卖系统【附ppt和万字文档(Lun文)和搭建文档】

主要功能 主要功能 前台登录: ①首页:轮播图、竞拍公告、拍卖商品展示 ②拍卖商品:分类:手机、数码、电器等,可以点击商品竞拍 ③竞拍公告:可以查看竞拍的信息 ④留言反馈:用户可以提交留言 ⑤…

如何办理跨境电商营业执照?加速度jsudo

如今电商行业的发展持续火热,跨境电商亦是如此,随着疫情的好转,各行各业也逐渐好转起来,此时也是一个做跨境电商的好时机,那么做跨境电商的前提需要什么呢?当然是营业执照了,那么如何办理跨境电商营业执照…

Flutter Ping 检查服务器通讯信号强度

Flutter Ping 检查服务器通讯信号强度 前言 对通讯敏感的程序中,我们除了检查当前网络通道外,还要检查与服务器实际的型号强度。 一般我们采用 ping 的方式返回型号的强度和稳定程度。 dart_ping 包 https://pub-web.flutter-io.cn/packages/dart_ping …

【Java】Java 链表类详记

本文仅供学习参考! 相关文章链接: https://www.runoob.com/java/java-linkedlist.html https://www.developer.com/java/java-linkedlist-class/ https://www.w3schools.com/java/java_linkedlist.asp Java 中链表的类型 从最基本的角度来说&#xff0c…

EBO绘制矩形

数据: float vertices[] { 0.5f, 0.5f, 0.0f, // top right 0.5f, -0.5f, 0.0f, // bottom right -0.5f, -0.5f, 0.0f, // bottom left -0.5f, 0.5f, 0.0f // top left }; unsigned int indices[] { // note that we start from 0! 0, 1, 3, // first triangle 1,…

UE4自定义资产类型编辑器实现

在虚幻引擎中,资产是具有持久属性的对象,可以在编辑器中进行操作。 Unreal 附带多种资源类型,从 UStaticMesh 到 UMetasoundSources 等等。 自定义资源类型是实现专门对象的好方法,这些对象需要专门构建的编辑器来进行高效操作。 …

SpringBoot3 快速入门及原理分析

1. 环境要求 环境&工具版本SpringBoot3.0.5IDEA2021.2.1Java17Maven3.5Tomcat10.0 2. SpringBoot是什么 SpringBoot 能帮我们简单、快速地创建一个独立的、生产级别的 Spring 应用(说明:SpringBoot底层是Spring) SpringBoot 应用只需…

CentOS7安装使用Nginx

CentOS7安装使用Nginx CentOS7安装使用Nginx1.安装1.1下载1.2 检验服务器上是否有nginx1.3 解压安装1.4 验证 2.部署2.1基本知识2.1.1常用命令2.1.2配置文件 2.2 配置效果前端后端 CentOS7安装使用Nginx 本文使用的nginx版本为1.22.1 Nginx发布版本分为主线版本和稳定版本&…

如何解决多线程卡死问题?四招教你轻松应对!

多线程大家都用过,可以让一个程序同时执行多个任务,提高效率和性能,一个人干的慢,三个人干。但是,多线程也带来了一些问题和挑战,比如线程同步、线程安全、线程死锁等问题,三个人抢一碗米饭&…

操作系统OS(一)磁盘与文件系统

计算机存储 计算机只能看懂1和0组成的语言,所以计算机存储数据的大小就是存储了多少个1和0. 比特位bit(位) 是计算机世界中最小的存储单位,每个1或者0占据1bit,表示二进制位 字节byte 由8个二进制位构成,1…

OpenGL 几何着色器

1.效果展示 爆破物体。 2.简介 在顶点和片段着色器之间有一个可选的几何着色器,几何着色器的输入是一个图元(如点或三角形)的一组顶点。几何着色器可以在顶点发送到下一着色器阶段之前对它们随意变换。然而,几何着色器最有趣的…

RabbitMQ 2023面试5题(四)

一、RabbitMQ有哪些作用 RabbitMQ是一个消息队列中间件,它的作用是利用高效可靠的消息传递机制进行与平台无关的数据交流,并基于数据通信来进行的分布式系统的集成,主要作用有以下方面: 实现应用程序之间的异步和解耦&#xff1a…