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是对集合功能的一种增强,主要用于对集合对象进 ...
随机推荐
- 7.算法竞赛中的常用JAVA API :String 、StringBuilder、StringBuffer常用方法和区别(转载)
7.算法竞赛中的常用JAVA API :String .StringBuilder.StringBuffer常用方法和区别 摘要 本文将介绍String.StringBuilder类的常用方法. 在j ...
- Python脚本文件中使用中文
Python做图形用户界面(GUI)开发时经常要在界面上显示中文,需要做如下处理(详见[1]和[2]2.3节): 在py文件的首行写上:# -- coding:utf-8 -- 保存py文件时要存为u ...
- Android Hello World程序开发过程
按照Building Your First App,详细过程如下: 安装SDK(如果网速慢,需要用离线安装的方法,见笔记 离线安装Android SDK的方法 ): 采用命令行开发方法(不用装Ecli ...
- Java调用阿里云短信接口发送手机验证码
前五步可参考阿里云服务文档:https://help.aliyun.com/document_detail/59210.html?spm=a2c4g.11174283.4.1.2b152c42DoJ7 ...
- Django推导 安装等
HTTP协议补充 四大特性: 基于请求响应 基于TCP/IP协议之上的应用层协议 无状态 不能保存用户信息(cookie,session,token) 短链接 请求数据格式: 请求首行(请求方式,ht ...
- null的坑 和 比较运算符、相等运算符的隐式转换问题 (在javascript中,null>=0 为真,null<=0 为真,null==0却为假,null到底是什么?)
null在关系运算中的坑 & 关系运算符的隐式转换问题 注意: 比较运算符 和 相等运算符 的 ECMAscript 语法实现不同. 比较运算符 和 相等运算符 对数据进行了隐式转换, 相当于 ...
- springboot整合多数据源解决分布式事务
一.前言 springboot整合多数据源解决分布式事务. 1.多数据源采用分包策略 2.全局分布式事务管理:jta-atomikos. ...
- 高德Web开发入门之一
高德Web开发 一.地图开发阐述 1)不管是高德地图的Web开发使用,亦或是百度地图的应用开发,都可以直接百度"高德地图/百度地图",进入地图首页下边"开放平台" ...
- C#多线程---ReaderWriterLock实现线程同步
一.简介 当我们需要对一个共享资源多次读取的时候,用前面Monitor的同步锁就没有必要了.因为同步锁每次只允许一个线程访问共享资源,其他线程都会阻塞. 此时,通过ReaderWriterLock类可 ...
- 【SOE】 ArcGIS Server对象扩展(SOE)开发注意事项
ArcGIS Server对象扩展(SOE)开发注意事项 1.SOE介绍 在ArcGIS 10.1中ArcGIS Server不在支持DCOM方式的连接,这也就意味着我们不能通过本地方式的连接使用A ...


