Vue3的新特性及相关的Composition API使用
首先 创建项目 Vue3
Vue3 相较于Vue2 的6大亮点:
1 性能快。 2 按需编译 体积更小 3 提供了组合API 类似于react 的React Hooks 4 更好的Ts支持 5 暴露了自定义渲染的API 6 更先进的组件。
使用Vue3 创建项目 1 webpack 2 Vue-cli 3 vite
什么是vite?
安装vite :
npm install -g create-vite-app
创建Vue3项目:
create-vite-app projectName
安装依赖运行项目:
cd projectName
npm install
npm run dev
组合API:
setup(){
}
函数是组合API的入口函数,通过导入ref实时监听变量的变化。并且通过组合API可以初始化变量的值。 最后通过return 暴露出去对象或者方法。
eg:
首先导入ref:
其次,定义setup()函数:
ref函数的注意点:ref函数只能监听简单类型的变化,不能监听复杂类型的变化 类似于(对象/数组等)
监听复杂类型的变化可以使用reactive函数来实现。
eg:
最后实现的整体的业务逻辑封装之后如下所示:
模块化管理 封装相关的功能函数并导出 之后再App.vue中导入使用:
组合API的本质及其使用:在使用过程中将Compisition API 数据和方法 注入到options API 的数据和方法当中。
setup函数执行时机以及注意点:
setup函数的执行时间,是在beforeCreate钩子执行之前完成的。因此在setup函数中是无法使用data 和methods 的。并且为了避免错误的使用,直接将setup函数中的this修改成了undefined。
setup函数只能是同步的,不能够是异步的。
reactive函数:是Vue3中提供的实现响应式数据的方法。
reactive函数必须传入一个对象(json 或者 array类型的都可以),本质是将传入的数据包装成一个Proxy对象。
如果传递了其他的对象,默认情况下修改对象,界面不会自动更新,如果需要跟新,则需要重新赋值。
ref的深刻理解:
ref 和reactive的区别:
Vue如何判断一个数据是否是ref类型的或者是reactive类型的:
由私有属性无法访问,因此如果要判断一个类型是否是ref类型的或者是reactive类型的 可以通过导入函数isRef isReactive来实现:
递归监听:
由于把每一层包装成一个Proxy对象,因此十分的消耗性能。
非递归监听:只能够监听第一层,不能够监听其他层。创建非递归的监听的数据 (reactive 对应 shallowReactive) , (ref 对应于 shallowRef )
shallowRef使用的注意点:
可以通过triggerRef()方法实现ref 数据的主动的更新页面数据。
shallowRef的本质:
toRaw方法:针对于reactive响应式数据的原始数据。
eg:
toRaw的主要使用特点:保存原始数据,只更新原始数据,并不修改UI界面。
获取ref类型的原始数据的方式:通过toRaw 方法 由于包装成了reactive方法 所以需要使用.value来获取原始的数据。
通过markRaw来实现永远都不会追踪原始数据:
toRef方法:
ref()方法对某一个对象中的属性进行操作:如果将对象中的某一个属性变为响应式数据,修改响应式的数据时不会影响到原始数据的变化。
ref() 和 toRef() 方法的区别和联系:
如果需要将某一个对象中的多个属性变为响应式数据,可以采用toRefs()函数来实现。 只有一个属性变为响应式数据的时候使用toRef()
import {toRefs } from 'vue'; setup(){
let obj = {name:"kkl",age:18};
let state = toRefs(obj);
// 使用toRef()实现属性变为响应式。
// let name = toRef(obj,"name");
// let age = toRef(obj,'age');
function myFun(){ state.name.value = "zs";
state.age.value = 22; }
return { state,myFun}
} 可以将对象中的属性全部变为响应式数据。
Vue3的新特性及相关的Composition API使用的更多相关文章
- Vue3.0新特性
Vue3.0新特性 Vue3.0的设计目标可以概括为体积更小.速度更快.加强TypeScript支持.加强API设计一致性.提高自身可维护性.开放更多底层功能. 描述 从Vue2到Vue3在一些比较重 ...
- vue3.0新特性以及进阶路线
Vue3.0新特性/改动 新手学习路线 ===> 起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要 ...
- 返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, .net 4.5 带来的更方便的异步操作
原文:返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, ...
- Java8新特性时间日期库DateTime API及示例
Java8新特性的功能已经更新了不少篇幅了,今天重点讲解时间日期库中DateTime相关处理.同样的,如果你现在依旧在项目中使用传统Date.Calendar和SimpleDateFormat等API ...
- 尝鲜 vue3.x 新特性 - CompositionAPI
0. 基础要求 了解常见的 ES6 新特性 ES6 的导入导出语法 解构赋值 箭头函数 etc... 了解 vue 2.x 的基本使用 组件 常用的指令 生命周期函数 computed.watch.r ...
- 简单梳理下 Vue3 的新特性
在 Vue3 测试版刚刚发布的时候,我就学习了下 Composition API,但没想到正式版时隔一年多才出来,看了一下发现还是增加了不少新特性的,在这里我就将它们一一梳理一遍. 本文章只详细阐述 ...
- Vue3的新特性
总概 1) 性能提升 打包大小减少 41% 初次渲染快 55%,更新渲染快 133% 内存减少 54% 使用 Proxy 代替 defineProperty 实现数据响应式 重写虚拟 DOM 的实现和 ...
- C#语言的新特性及相关信息
.ENT版本 NET 2.0 :CLR, WinForms ,Wed Services,ASP.NET NET 3.0 :WCF,WF,WPF,CardSpace NET 3.5 :LINQ ,AJ ...
- Java8新特性第3章(Stream API)
Stream作为Java8的新特性之一,他与Java IO包中的InputStream和OutputStream完全不是一个概念.Java8中的Stream是对集合功能的一种增强,主要用于对集合对象进 ...
随机推荐
- anaconda的报错:Anaconda:There is an instance of anaconda navigator already running error
anaconda的报错:Anaconda:There is an instance of anaconda navigator already running error 出现这个问题的时候人蒙了,主 ...
- noip17
复杂度分析全部摘自题解 T1 sb优化暴力 暴力20-40pts,我只拿了20pts. 正解: bitset 优化暴力,但是会MLE. 再次考虑如何优化,我们统计一下每个点的入度,每次遍历到这个点的时 ...
- redis和memecache有什么区别?
1.memcache所有值均是简单地字符串,redis有复杂的数据类型. 2.memcache不支持数据持久化,redis支持数据持久化. 3.redis速度比memcache快,redis构建了自己 ...
- flutter实现文字超出最大宽度显示省略号
Container( width: 60, child: Text( '...', maxLines: 1, overflow: TextOverflow.ellipsis, ), ) 给Text外层 ...
- FTP 大文件传输问题 解决
问题描述 将附件上传至FTP服务器,但是当附件过大,其大小为几百兆或1-2G时,会出现上传失败的现象 FTP上传原理解析 这里我们使用的是.Net的FtpWebRequest 创建FtpClient ...
- 嵌入式Linux的启动过程
1.了解 Linux 最初是由瑞典赫尔辛基大学的学生 Linus Torvalds在1991 年开发出来的,之后在 GNU的支持下,Linux 获得了巨大的发展.虽然 Linux 在桌面 PC 机上的 ...
- Jmeter教程 录制脚本
Jmeter 录制脚本 Jmeter中有2种方法可以录制脚本. 不过我个人非常不推荐录制脚本,录制的脚本混乱,需要再次加工才能使用. 像我这么精通HTTP协议的人. 一直都是使用Fiddler来抓包 ...
- Map 综述(一):彻头彻尾理解 HashMap
转载自:https://blog.csdn.net/justloveyou_/article/details/62893086 摘要: HashMap是Map族中最为常用的一种,也是 Java Col ...
- 关于Typora的使用
关于Typora的使用 今天介绍一个做笔记用的一款markdown编辑器,用了之后,顺利被圈粉: Typora,美观小众,可用性强! 和传统的markdown编辑器不一样,传统的markdown编辑器 ...
- bt面板安装邮局系统
前些日子阿里云优惠就顺便买了个服务器,今天想在阿里云的服务器上试着安装一个邮件服务,突然发现之前安装的好好的邮件服务插件不能正常安装了,一直报错. 点击该链接享受本文章的纯净无广告版 查看了下出错的地 ...