首先 创建项目 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使用的更多相关文章

  1. Vue3.0新特性

    Vue3.0新特性 Vue3.0的设计目标可以概括为体积更小.速度更快.加强TypeScript支持.加强API设计一致性.提高自身可维护性.开放更多底层功能. 描述 从Vue2到Vue3在一些比较重 ...

  2. vue3.0新特性以及进阶路线

    Vue3.0新特性/改动 新手学习路线  ===> 起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要 ...

  3. 返璞归真 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 上传文件, ...

  4. Java8新特性时间日期库DateTime API及示例

    Java8新特性的功能已经更新了不少篇幅了,今天重点讲解时间日期库中DateTime相关处理.同样的,如果你现在依旧在项目中使用传统Date.Calendar和SimpleDateFormat等API ...

  5. 尝鲜 vue3.x 新特性 - CompositionAPI

    0. 基础要求 了解常见的 ES6 新特性 ES6 的导入导出语法 解构赋值 箭头函数 etc... 了解 vue 2.x 的基本使用 组件 常用的指令 生命周期函数 computed.watch.r ...

  6. 简单梳理下 Vue3 的新特性

    在 Vue3 测试版刚刚发布的时候,我就学习了下 Composition API,但没想到正式版时隔一年多才出来,看了一下发现还是增加了不少新特性的,在这里我就将它们一一梳理一遍. 本文章只详细阐述 ...

  7. Vue3的新特性

    总概 1) 性能提升 打包大小减少 41% 初次渲染快 55%,更新渲染快 133% 内存减少 54% 使用 Proxy 代替 defineProperty 实现数据响应式 重写虚拟 DOM 的实现和 ...

  8. C#语言的新特性及相关信息

     .ENT版本 NET 2.0 :CLR, WinForms ,Wed Services,ASP.NET NET 3.0 :WCF,WF,WPF,CardSpace NET 3.5 :LINQ ,AJ ...

  9. Java8新特性第3章(Stream API)

    Stream作为Java8的新特性之一,他与Java IO包中的InputStream和OutputStream完全不是一个概念.Java8中的Stream是对集合功能的一种增强,主要用于对集合对象进 ...

随机推荐

  1. anaconda的报错:Anaconda:There is an instance of anaconda navigator already running error

    anaconda的报错:Anaconda:There is an instance of anaconda navigator already running error 出现这个问题的时候人蒙了,主 ...

  2. noip17

    复杂度分析全部摘自题解 T1 sb优化暴力 暴力20-40pts,我只拿了20pts. 正解: bitset 优化暴力,但是会MLE. 再次考虑如何优化,我们统计一下每个点的入度,每次遍历到这个点的时 ...

  3. redis和memecache有什么区别?

    1.memcache所有值均是简单地字符串,redis有复杂的数据类型. 2.memcache不支持数据持久化,redis支持数据持久化. 3.redis速度比memcache快,redis构建了自己 ...

  4. flutter实现文字超出最大宽度显示省略号

    Container( width: 60, child: Text( '...', maxLines: 1, overflow: TextOverflow.ellipsis, ), ) 给Text外层 ...

  5. FTP 大文件传输问题 解决

    问题描述 将附件上传至FTP服务器,但是当附件过大,其大小为几百兆或1-2G时,会出现上传失败的现象 FTP上传原理解析 这里我们使用的是.Net的FtpWebRequest 创建FtpClient ...

  6. 嵌入式Linux的启动过程

    1.了解 Linux 最初是由瑞典赫尔辛基大学的学生 Linus Torvalds在1991 年开发出来的,之后在 GNU的支持下,Linux 获得了巨大的发展.虽然 Linux 在桌面 PC 机上的 ...

  7. Jmeter教程 录制脚本

    Jmeter 录制脚本 Jmeter中有2种方法可以录制脚本.  不过我个人非常不推荐录制脚本,录制的脚本混乱,需要再次加工才能使用. 像我这么精通HTTP协议的人. 一直都是使用Fiddler来抓包 ...

  8. Map 综述(一):彻头彻尾理解 HashMap

    转载自:https://blog.csdn.net/justloveyou_/article/details/62893086 摘要: HashMap是Map族中最为常用的一种,也是 Java Col ...

  9. 关于Typora的使用

    关于Typora的使用 今天介绍一个做笔记用的一款markdown编辑器,用了之后,顺利被圈粉: Typora,美观小众,可用性强! 和传统的markdown编辑器不一样,传统的markdown编辑器 ...

  10. bt面板安装邮局系统

    前些日子阿里云优惠就顺便买了个服务器,今天想在阿里云的服务器上试着安装一个邮件服务,突然发现之前安装的好好的邮件服务插件不能正常安装了,一直报错. 点击该链接享受本文章的纯净无广告版 查看了下出错的地 ...