Vue3基本功能介绍

文章目录

    • Vue3组件中的模板结构可以没有根标签div
    • 组合式API
    • Ref
    • Reactive函数
    • 回顾Vue2响应式
    • Vue3实现响应式
    • 对比reactive和ref
    • Setup注意点
    • 计算属性与监听computed
    • Watch
    • WatchEffect
    • Vue3生命周期
    • 自定义hook函数
    • toRef
    • 其他组合API
    • shallowReactive
    • shallowRef
    • readonly和shallowOnly
    • ToRaw和markRow
    • customRef
    • Provide和inject
    • 响应式数据的判断
    • Composition API的优势
    • 新的组件
    • Fragment
    • Teleport
    • Suspense
    • Vue3其他变化

Vue3组件中的模板结构可以没有根标签div

在这里插入图片描述

组合式API

  1. Setup
    Vue3中的一个新的配置项,是一个函数;
    组件中所用到的数据、方法等等,均要配置在setup中;
    Setup函数的两种返回值:
    1)若返回一个对象,则对象的属性、方法,在模板中均可以直接使用。(常用)
    在这里插入图片描述
    2)若返回一个渲染函数,可以自定义渲染内容。
    在这里插入图片描述
    在这里插入图片描述

注意点:
1、尽量不要与vue2.x配置使用
*Vue2配置(data,methods,computed…)中可以访问到vue3的setup中的属性、方法。
*vue3的setup中的配置不能访问到Vue2的配置(data,methods,computed…)。
*如果有重名,setup优先。
2、setup不能是一个async函数,因为如果是async函数,返回值不再是return的对象,而是promise,模板中将看不到return中的属性。

Ref

RefImpl:引用对象,如果想让一个普通变量变成响应式的,就需要把这个变量丢给ref。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述修改的时候需要使用name.value进行修改。使用的时候直接使用name字段就行。
补充:const obj= {name:’li’}定义的对象是可以修改对象里面的属性,如:obj.name = ‘ni’
但是不可以修改整个对象,比如:obj = {name:’ni’}
Ref作用:定义一个响应式的数据。
Ref语法:
1)创建一个包含响应式数据的引用对象
在这里插入图片描述2)JS中操作数据,使用XXX.value。
3)模板中使用,不需要value,直接{{XXX}}。

Ref接收的数据类型:基本类型,对象类型。
const a = ref(1); Const a = ref(‘1’); const a = ref(true); const a = ref({}); const a = ref([])

基本数据类型:响应式依靠的是object.defineProperty()的get和set。
对象类型:内部求助了vue3的一个新函数——reactive函数。

Reactive函数

作用:定义一个对象类型的响应式数据(基本类型不要用它,要用ref函数)。
使用ref定义的响应式数据,在js中修改的时候必须加上.value;使用reactive定义的响应式数据,不用.value就可以进行修改,无论对象层级有多深,数组也可以直接用索引来修改。
在这里插入图片描述
语法:const 代理对象 = reactive(原对象),接受一个对象或数组,返回一个代理对象(proxy的实例对象,简称proxy对象)。

Reactive定义的响应式数据是’深层次’的。
内部基于ES6的proxy实现,通过代理对象操作源对象内部数据进行操作。

回顾Vue2响应式

存在问题:
新增属性,删除属性,界面不会更新。
直接通过下标修改数组界面不会自动更新。
在这里插入图片描述
在这里插入图片描述Vue2使用object.defineProperty来劫持数据是否发生改变,如下:
在这里插入图片描述
在这里插入图片描述能监测到获取和修改属性:
在这里插入图片描述
新增的属性没有get和set:

在这里插入图片描述
删除name属性:
在这里插入图片描述综上,获取和修改一个属性可以捕获到,但是新增和删除属性是捕获不到的,所以使用 s e t 和 set和 setdelete方法才能响应。

Vue3实现响应式

  1. 如下代码,p = new Proxy()后,p是一个proxy对象,是person的一个代理对象,对p的修改会映射到person身上:
    在这里插入图片描述在这里插入图片描述
    上面代码只是说P是person的代理对象,p改变,person跟着改变,但是并没有做到响应式,也就是变化并没有捕获到。
  2. Vue3捕获响应:
    在这里插入图片描述结果如下:对对象的增删改查全部捕获到,并且映射到person中。
    其中set方法,既捕获新增又捕获修改。
    在这里插入图片描述
  3. 对上面代码进行优化,vue3中是使用Reflect来对数据进行修改。
    在这里插入图片描述

综上,实现原理: 通过proxy(代理):拦截对象中任意属性的变化,包括:属性值的读写,属性的添加,属性的删除等。
通过Reflect(反射):对被代理对象(原对象)的属性进行操作。

对比reactive和ref

  1. 从定义数据角度对比
    Ref用来定义:基本数据类型。
    Reactive用来定义:对象(或数组)类型数据。
    备注:ref也可以定义对象(或数组)类型数据,它内部会自动通过reactive转为代理对象。
  2. 从原理角度对比
    Ref通过object.defineProperty()的get和set来实现响应(数据劫持)。
    Reactive通过proxy来实现响应式(数据劫持),通过Reflect来操作源数据内部。
  3. 从使用角度对比
    Ref定义的数据,操作数据需要使用.value,模板中使用数据不需要使用.value。
    Reactive定义的数据,操作数据与读取数据,均不需要使用.value。

Setup注意点

  1. Setup执行时机:beforeCreate之前执行一次,这个时候的this是undefined。
    Setup一共有两个参数,第一个是父组件传过来的值:
    在这里插入图片描述
    在这里插入图片描述

在这里插入图片描述
第二个参数是:context
在这里插入图片描述
在这里插入图片描述
Context.attrs:值为对象,包含:组件外部传递过来,但是没有在props配置中声明的属性,相当于this. a t t r s 。 C o n t e x t . e m i t :分发自定义事件的函数,相当于 t h i s . attrs。 Context.emit:分发自定义事件的函数,相当于this. attrsContext.emit:分发自定义事件的函数,相当于this.emit。(下面举例)
Context.slots:收到的插槽内容,相当于this.$slots。(下面举例)
Context.emit使用:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Context.slots使用:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

计算属性与监听computed

与vue2中的computed配置功能一致。
写法:
在这里插入图片描述

Watch

Watch在vue3中是一个组合API,可以多次调用,它有三个参数:
Params1:被监听的变量,可以是一个数组,存放多个变量。
Params2:回调函数,监听的数据有变化时调用,回调函数中有两个参数,newVal和oldVal。
Params3:是一个对象,存放watch的配置{immediate:true,deep:true}。

  1. Watch监听ref变量
    在这里插入图片描述
    在这里插入图片描述
  2. Watch监听reactive变量
    Vue3bug:
    1)watch监听reactive变量时,oldValue值获取不到。
    2)强制开启了深度监听,deep配置无效。
    在这里插入图片描述在vue3中,不管嵌套的层级有多深,只要是用reactive定义的,都可以监听到。但是获取不到正确的oldVal。
    情况三:监听reactive定义的嵌套多级的对象,不管嵌套层级有多深,都是深度监听
    在这里插入图片描述
    在这里插入图片描述
    情况四,监听reactive定义的响应式对象中的某一属性。使用回调函数的方式。并且可以获取到oldValue值。
    在这里插入图片描述
    在这里插入图片描述
    情况五:监视reactive定义的响应式对象的某些属性。可以成功获取oldVal。
    在这里插入图片描述
    在这里插入图片描述
    特殊情况:监听salary,要使用deep。拿不到oldValue。
    在这里插入图片描述
    总结:
    在这里插入图片描述
    在这里插入图片描述答疑:
    1、为什么监听ref定义的基本数据类型不需要使用.value,监听ref定义的引用类型的数据需要使用.value。
    监听ref定义的基本数据类型:监听的是RefImpl对象。
    监听ref定义的引用类型数据,监听的是RefImpl对象,但是RefImpl中的value值是Proxy对象,需要深度监听,所以需要使用{deep:true},或者监听person.value。
    在这里插入图片描述

WatchEffect

Watch:既要指明监视的属性,又要指明监视的回调。
WatchEffect:不用指明监视的属性,监视的回调中用到了哪个属性,就监视哪个,而且深度监听。
WatchEffect有点像computed:
1)但computed注重的是计算出来的值(回调函数的返回值),所以必须要写返回值。
2)而WatchEffect注重的是过程(即函数体),所以不用写返回值。

如下例子,person.salary.s1.sa发生变化了就会被监听到。
在这里插入图片描述

Vue3生命周期

第一种使用方式——配置项的方式
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:
1)使用配置项这种方式的生命周期,setup在所有生命周期之前执行。
2)最后两个生命周期在vue2中是beforeDestroy和destroyed,vue3中改成了beforeUnmount和unmounted。

第二种使用方式——组合式API
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:
1)使用组合API生命周期钩子,onBeforeCreate和onCreated两个钩子没有API,就相当于setup。

自定义hook函数

Vue3的hook函数,相当于vue2的 mixin,不同在于hooks是函数。
Vue3的hook函数,可以帮助我们提高代码的复用性, 让我们能在不同的组件中都利用 hooks 函数。
例子:将鼠标点击页面就获取坐标点的方法拿出独立,便于其他组件复用。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

toRef

作用:创建一个ref对象,其value值指向另一个对象中的某个属性。
语法:const name = toRef(device,’name’).
应用:要将响应式对象中的某个属性单独提供给外部使用时。
在这里插入图片描述
扩展:toRefs和toRef功能一样,但是可以创建多个ref对象,语法:toRefs(device)。
在这里插入图片描述

其他组合API

shallowReactive

作用:浅层次的响应式,只考虑第一层的响应式。
如下举例:name和age会响应,但是position.po.p不是响应式的。
在这里插入图片描述

shallowRef

只处理基本数据类型的响应式,不进行对象的响应式处理。
如果使用ref,处理对象时,内部借用的是reactive方法,使用ES6的proxy,shallowRef没有做这个操作,所以不能对对象进行响应式处理。
在这里插入图片描述
在这里插入图片描述何时使用?
1)如果有一个对象,结构比较深,但是变化时只是外层属性发生变换,使用shallowReactive。
2)如果有一个对象,后续功能不会修改该对象里面的属性,而是生成新的对象来替换,使用shallowRef。

readonly和shallowOnly

readonly:是一个函数,接收一个响应式的数据,相当于将这个响应式的数据保护起来,不能进行修改。
在这里插入图片描述
shallowOnly:让一个响应式的数据变为只读的,不可修改(浅只读),浅只读就是对于嵌套层级的对象来说,只能对第一级进行只读操作,其他级依然是响应式。
在这里插入图片描述
应用场景:不希望数据被修改时。

ToRaw和markRow

markRow应用几率高。
ToRaw:把reactive定义的响应式数据转成原始数据(没有响应式)。
使用场景:用于读取响应式对象对应的普通对象,对这个普通对象的所有操作,不会引起页面更新。
注:ref定义的无效。

在这里插入图片描述
在这里插入图片描述
markRow:标记一个对象,使其永远不会再成为响应式对象。
应用场景:
1、有些值不应被设置为响应式,例如复杂的第三方类库;
2、当渲染具有不可变数据源的大列表时,跳过响应式转换可以提高性能。(例如一个层级很深很深的数据,vue3会一层一层的做响应式,如果这个数据只是展示使用,不需要对其进行修改,可以使用markRaw标记为普通对象,从而提高性能。)

小插曲:如果动态给一个响应式的对象中添加属性,要么一开始定义这个对象的时候就先将这个属性定义出来;如果使用toRef(),就需要先将这个大对象抛出去,否则第一次进去页面报错。

在这里插入图片描述给reactive定义的响应式数据身上追加任何属性,都是响应式的属性。

在这里插入图片描述
在这里插入图片描述
使用markRaw标记后,car不再是响应式的。
在这里插入图片描述
在这里插入图片描述

customRef

作用:创建一个自定义的ref,并对其依赖项跟踪和更新触发进行显式控制。
注:customRef函数调用要传入一个函数,函数体里面要返回一个对象。
举例:实现防抖效果(在输入框中输入的东西,过500ms再在下面显示出来)

在这里插入图片描述

Provide和inject

作用:实现祖和后代组件(跨级)间通信。
套路:父组件有一个provide选项来提供数据,后代任何一级的组件(包括子组件,即第一级组件,但是没必要,子组件使用props就好。)有一个inject选项来开始使用这些数据。
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

响应式数据的判断

isRef:检查一个值是否为一个ref对象。
isReactive:检查一个对象是否是由reactive创建的响应式代理。
isReadonly:检查一个对象是否是由readonly创建的只读代理。
isProxy:检查一个对象是否是由reactive或者readonly方法创建的代理。
在这里插入图片描述

Composition API的优势

使用传统的opsitionApi,新增或者修改一个需求,就需要分别在data,methods,computed中修改。使用compositionAPI我们可以更优雅的组织我们的代码,函数,让相关功能的代码更加有序的组织到一起。
在这里插入图片描述
在这里插入图片描述

新的组件

Fragment

在vue2中,组件要有一个根标签;
在vue3中,组件可以没有根标签,内部会将多个标签包裹在一个虚拟的Fragment元素中。好处:减少标签层级,减少内部占用。
在这里插入图片描述

Teleport

Teleport是一种能将我们的组件html结构传送到指定位置的技术。
举例:父组件中引入子组件,子组件中引入孙组件,孙组件中引入dialog组件:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
正常来讲,html结构是:弹窗在孙组件中,不能移动到body体内。
在这里插入图片描述
使用teleport包裹后,可以将包裹的内容移动到任意位置
在这里插入图片描述
将弹窗相关的html结构移动到了body的位置。

在这里插入图片描述

Suspense

等待异步组件时渲染一些额外内容,让用户有更好的体验。
使用步骤:
在这里插入图片描述举例:将子组件放在suspense中包裹起来,再异步引入。
在这里插入图片描述显示效果:子组件显示显示‘稍等,加载中…’,再显示child组件中真正的内容。
在这里插入图片描述
补充内容:
之前说过,setup不能是一个async函数,因为返回值不再是return的对象,而是promise,模板看不到return中的属性。
但其实,setup可以是async函数,也可以返回一个promise对象,但需要suspense和异步引入组件的配合。
在这里插入图片描述
让组件等一等再加载出来的两种方法:
1、使用了异步组件,异步引入,suspense,网速慢;
2、使用promise。

Vue3其他变化

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
例如如下两种写法,都是依赖按键code。
移除:@keyup.13 = “fn” 的写法;
移除:Vue.config.keyCodes.huiche = 13 //定义了一个别名按键
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

赋能企业高效精准的EDM邮件群发推广

数字化营销日益成为商业增长引擎,云衔科技以其创新的智能EDM(Electronic Direct Mail)邮件群发推广解决方案,帮助企业客户突破传统营销模式,实现业绩飞跃和品牌影响力的大幅提升。 作为数字化广告营销及SaaS软件服务领…

安装mysql5.7.26一个报错问题

首先先安装mysql5.7.26,因为要求安装的版本要和原来的一样,数据路径也要和原来一致 一、安装mysql5.7.26 mysql官网各种版本下载网址 MySQL :: Download MySQL Community Server (Archived Versions) 1、下载mysql安装包 2、环境准备 centos7.9 mysql5.7.26包…

【简单介绍下Faiss原理和使用】

🎥博主:程序员不想YY啊 💫CSDN优质创作者,CSDN实力新星,CSDN博客专家 🤗点赞🎈收藏⭐再看💫养成习惯 ✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出…

有哪些公认好用且免费的云渲染网渲平台?渲染100邀请码1a12

现在云渲染是越来越火了,无论是在建筑设计、影视动画还是效果图行业都有它的身影,云渲染能缩短制作周期,提高工作效率,那么市面上有哪些公认好用且免费的云渲染平台呢?这次我们来了解下。 首先,我们来看看有…

牛客Linux高并发服务器开发学习第三天

静态库的使用(libxxx.a) 将lession04的文件复制到lession05中 lib里面一般放库文件 src里面放源文件。 将.c文件转换成可执行程序 gcc main.c -o app main.c当前目录下没有head.h gcc main.c -o app -I ./include 利用-I 和head所在的文件夹,找到head。 main.c…

Redis中的Lua脚本(五)

Lua脚本 脚本复制 复制EVALSHA命令 EVALSHA命令式所有与Lua脚本有关的命令中,复制操作最复杂的一个,因为主服务器与从服务器载入Lua脚本的情况可能有所不同,所以主服务器不能像复制EVAL命令、SCRIPT LOAD命令或者SCRIPT FLUSH命令那样&…

[大模型]Qwen-7B-Chat 接入langchain搭建知识库助手

Qwen-7B-Chat 接入langchain搭建知识库助手 环境准备 在autodl平台中租一个3090等24G显存的显卡机器,如下图所示镜像选择PyTorch–>2.0.0–>3.8(ubuntu20.04)–>11.8 接下来打开刚刚租用服务器的JupyterLab,并且打开其中的终端开始环境配置…

河北专升本(c语言各种编程题)

目录 第一类、递归调用 第二类、特殊数字 第三类、多维数组 第四类、字符处理 第五类、数学问题 第六类、排序算法 第七类、循环问题 第八类、进制转换 第九类、实际应用 第十类、图形输出 第一类、递归调用 1.汉诺塔:请输入盘子数,输出盘子移动…

05_Flutter屏幕适配

05_Flutter屏幕适配 一.屏幕适配方案 通过指定基准屏宽度,进行适配,基准屏宽度取决于设计图的基准宽度,以iphone 14 pro max为例, devicePixelRatio 物理宽度 / 逻辑宽度(基准宽度) iphone 14 pro max的物理尺寸宽度为1290&…

基于SSM的购物小程序01

4.1系统架构设计 购物系统设计的系统项目的概述设计分析,主要内容有学习平台的具体分析,进行数据库的是设计,数据采用mysql数据库,并且对于系统的设计采用比较人性化的操作设计,对于系统出现的错误信息可以及时做出处…

【Linux系统】地址空间 Linux内核进程调度队列

1.进程的地址空间 1.1 直接写代码&#xff0c;看现象 1 #include<stdio.h>2 #include<unistd.h>3 4 int g_val 100;5 6 int main()7 {8 int cnt 0;9 pid_t id fork();10 if(id 0)11 {12 while(1)13 {14 printf(&…

如何用flutter写一个好的登录页面

编写一个好的登录页面是构建用户友好且安全的移动应用的重要一步。下面是使用Flutter编写一个好的登录页面的一些建议和步骤&#xff1a; 1. 设计用户界面 1.简洁明了的布局&#xff1a;确保界面简洁明了&#xff0c;不要过分复杂&#xff0c;避免用户感到困惑。 2.清晰的输入框…

SQL刷题---2021年11月每天新用户的次日留存率

解题思路&#xff1a; 1.首先算出每个新用户注册的日期,将其命名为表a select uid,min(date(in_time)) dt from tb_user_log group by uid2.计算出每个用户登录的天数,将其命名为表b select uid,date(in_time) dt from tb_user_log union select uid,date(out_time) dt fro…

校园小情书微信小程序源码/社区小程序前后端开源/校园表白墙交友小程序

校园小情书前端代码&#xff0c;好玩的表白墙、树洞、校园论坛&#xff0c;可独立部署&#xff0c;也可以使用我部署的后台服务&#xff0c;毕业设计的好项目。 搭建教程&#xff1a; 一、注册管理后台 1、登录小情书站点进行注册&#xff1a;https://你的域名 2、注册成功…

使用Docker搭建一主二从的redis集群

文章目录 一、根据基础镜像构建三个docker容器二、构建master机三、配置slave机四、测试 本文使用 主机指代 物理机、 master机指代“一主二从”中的 一主&#xff0c; slave机指代“一主二从”中的 二从 一、根据基础镜像构建三个docker容器 根据本文第一章&#xff08…

小红书笔记写作方法和技巧分享,纯干货!

很多小伙伴感叹小红书笔记流量就是一个玄学&#xff0c;有时精心撰写的笔记却没有人看&#xff0c;自己随便写的笔记却轻轻松松上热门。实际上你还是欠点火候&#xff0c;小红书笔记写作是有一套方法和技巧的&#xff0c;总归是有套路的&#xff0c;如果你不知道&#xff0c;请…

YOLOv5检测框crop、MobileNetv3分类网络

在实际深度学习项目中&#xff0c;目标检测算法检测出的目标也会作为分类网络的输入数据&#xff0c;利用目标检测算法的对被检测图像进行抠图&#xff0c;以抠出来的图来扩充分类网络的数据。本文主要讲解yolov5和mobilenetv3结合使用扩展数据样本。 目录 1、yolov5检测框cro…

CTFHub(web sql注入)(二)

布尔盲注 盲注原理&#xff1a; 将自己的注入语句使用and与?id1并列&#xff0c;完成注入 手工注入&#xff1a; 爆库名长度 首先通过折半查找的方法&#xff0c;通过界面的回显结果找出数据库名字的长度&#xff0c;并通过相同的方法依次找到数据库名字的每个字符、列名…

EasyExcel追加写入数据,分批查询多次写入场景下,注意使用方式【OOM警告】

使用.withTemplate(file) 将临时数据文件和真实数据文件合并的方式&#xff0c;在生产环境大批量数据下&#xff0c;完全不可取&#xff0c;有很高的内存溢出风险 伪代码 public static void writeAppend(String fileName) {String filePath "tempDir".concat(Fil…

Docker操作容器打包(commit),压缩(save),挂载(load)

文章目录 前言一、容器打包二、将镜像压缩成tar包三、将tar包挂载为镜像结束 前言 将容器打包成镜像时&#xff0c;你正在将应用程序及其所有依赖项、文件和配置文件捆绑到一个可移植的、独立的单元中。这样做可以确保您的应用程序在不同环境中具有一致的运行方式&#xff0c;…