vue3 到底哪里好?看这一篇就够了
之前写的关于 vue3 的文章,好多人吐槽:这些API每次使用都要引入一遍,感觉有点麻烦。
今天我们就来看看 vue3 相比 vue2 的优点有些啥?
为啥有些人说:自从写了 ts vue3 再也回不到 vue2 啦!
vue3 到底哪里好?有的人回不到 vue2,而有的人去不了vue3!喜欢的点赞收藏,复盘不迷路!
一、Vue3 新增的几个亮点:
- Performance:性能优化
- Tree-shaking :支持摇树优化
- Composition API :组合式api
- 新增组件:Fragment、Teleport、Supense
- 更好地支持 ts
- Custom Render API:自定义渲染器
二、性能方面的提升
在性能方面,vue3 相比 vue2 ,性能提升了 1.3 ~ 2 倍左右。我们就来看看它是在哪些方面,如何提升的?
2.1、响应式性能提升
1> diff方法优化
diff 算法是虚拟 DOM 技术的必然产物,它会对新旧 DOM 进行比较,然后将变化的 DOM 更新在真实的 DOM 上。
在 vue2 中,数据发生变化的时候,会生成一个新的 DOM 树,然后和之前的 DOM 树进行比较,找到不同的节点然后更新到真实的 DOM 上,比较的过程中,会对没有发生改变的 DOM 也都会进行比较,就会消耗一定的时间。
在 vue3 中,在创建虚拟 DOM 的时候,会根据 DOM 中的内容添加一个静态标记,在数据发生改变的时候,就会带着静态标记的节点去对比,能够快速找到变化的 DOM 。
2> 事件侦听器缓存
默认情况下onClick会被视为动态绑定,所以每次都会追踪它的变化
但是因为是同一个函数,所以不用追踪变化,直接缓存起来复用即可
3> ssr渲染
当存在大量静态内容时,这些内容会被当做纯字符串推进一个 buffer 内,即使存在动态绑定,也会通过模板插值潜入进去,这样会比虚拟 DOM 渲染快得多。
2.2、代码体积方面
打包大小减少41%。
vue3 移除了一些不常用的 API,如:inline-template、filter 等,使用 tree-shaking。
Tree Shaking 摇树优化,指的就是当我们引入一个模块的时候,不引入这个模块的所有代码,只引入我们需要的代码。
在 vue2 中,很多函数都挂载到全局 Vue 对象上,如:nextTick、set 函数等,虽然我们不常用,但打包时只要引入 Vue 这些全局函数会打包进 bundle 中。而 vue3 中,引入tree-shaking,所有的 API 都通过 ES6 模块化的方式引入,这样就能够让 webpack 或 rollup 等打包工具在打包时,就会自动对没有用到的 API 进行剔除,最小化 bundle 体积。
初次渲染快55%, 更新渲染快133%。组件选择了按需引入,使得打包后的体积也更小了,所以项目运行的时候速度更快,更顺畅了!
2.3、编译被优化
1> 静态提升
在 vue2 中,无论元素是否参与更新,每次都会重新创建然后再渲染。
vue3 使用静态提升后,对于不参与更新的元素,只会被创建一次,在渲染时直接复用就好了。
2> Fragment
模板内不用再创建一个唯一根节点,可以直接放同级标签和内容。就相当于少了一个节点嵌套渲染。
三、选项式 api VS 组合式 api
3.1、vue3 的组合式 api 相对来说,更有利于维护和封装。
3.2、组合式 api 高内聚,低耦合。
在 vue2 中采用选项式 api ,会在 vue 文件的 data、methods、watch、computed 中定义属性和方法,共同处理页面逻辑,多个功能相互交叉,缠绕在一起,代码过于分散。
而 vue3 新增了组合式 api ,一个功能模块代码会集中到一起,实现高内聚,低耦合。提高代码的可读性和可维护性,基于函数组合的 api 更好地重用逻辑代码。
组合式api 与 选项式api 对比如下图:
每个颜色,都代表着一个功能。
3.3、不宜出现 DOM 元素不存在问题。
vue3 中用 setup 函数代替了 vue2 中的 beforeCreate 和 created 。有些同学有时候会在 created 中操作 DOM 元素,有时候报错了,就在那纳闷看不出来问题,为了没有反应。使用 setup 之后,就不容易出现该问题了。
注意:
vue3 的组合式 api 中的 onUnmounted 代替了 vue2 中的 beforeDestory。
vue3 的组合式 api unmounted 代替了 vue2 中的 destoryed 。
四、proxy 相对 Object.defineProperty 优点有哪些?
proxy 和 Object.defineProperty 都是来实现响应式数据的。
vue3 使用 proxy 来代替 vue2 的 Object.defineProperty 效率更高,值得学习。
1> vue2 利用 Object.defineProperty 来劫持 data 数据的 getter 和 setter 操作,使得 data 在被访问或赋值时,动态更新绑定的 template 模板。而 Object.defineProperty 必须遍历所有的预值才能劫持每一个属性,这一缺点正好能够被 proxy 解决。
proxy 相比 Object.defineProperty 优点分别为:
- 代码的执行效果更快。
- proxy 可以直接监听对象而不是它的属性。
- proxy 可以直接监听数组的每个元素的变化。
- proxy 不需要初始化的时候遍历所有属性,如果有多层嵌套的话,只访问某个属性的时候,proxy 能够快速访问到,而 Object.defineProperty 还需要遍历所有属性,然后逐级向下访问。
- proxy 返回的是一个新对象,可以直接操作新对象而达到目标。而 Object.defineProperty 操作的是原对象,只能遍历对象属性然后对其直接修改。
- proxy 有 13 种拦截方法,不限于 apply、ownKeys、deleteProperty 等,而 Object.defineporperty 不具备。
2> defineProperty 无法监听对象新增属性以及无法跟踪数组索引以及数组 length 的问题,proxy 正好解决了该问题。
在 vue2 中,我们给对象新增一个属性时,如果新增属性的值发生改变的时候,我们发现视图并没有更新,因为新增属性是无法监听到的。同样的,通过下标直接改变数组,视图也是无法更新的,也是因为监听不到。
在 vue3 中新增 proxy ,解决了这些问题。
五、更好的 ts 支持
vue2 不适合使用 ts,在于它的 Options API 风格。
options 是一个简单的对象,而 ts 是一种类型系统、面向对象的语法,两个不匹配。
vue3 新增了 defineComponent 函数,使组件在 ts 下,更好的利用参数类型推断。如:reactive 和 ref 很具有代表性。
六、更先进的组件
1> Fragment
在 vue2 中,每个模板必须有一个根节点,否则就会报错。
vue3 中可以不需要根节点,多个元素或标签可并列存在。
2> Teleport
传送门。可以把 teleport 中的内容添加到任意的节点内,对于嵌套较深的组件来说绝对是一个福音。
3> Supense
允许程序在等待异步组件渲染一些后备的内容,可以让我们创建一个平滑的用户体验。
总结:
vue 目前是国内最火的前端框架之一,vue3 性能提升、运行速度也比 vue2 好很多。
总之 vue3 就是:
- 让项目更快
- 让代码更少
- 更易于维护
- 让我们开发更快,加班更少
vue3 到底哪里好?看这一篇就够了的更多相关文章
- 关于 Docker 镜像的操作,看完这篇就够啦 !(下)
紧接着上篇<关于 Docker 镜像的操作,看完这篇就够啦 !(上)>,奉上下篇 !!! 镜像作为 Docker 三大核心概念中最重要的一个关键词,它有很多操作,是您想学习容器技术不得不掌 ...
- JVM内存模型你只要看这一篇就够了
JVM内存模型你只要看这一篇就够了 我是一只孤傲的鱼鹰 让我们不厌其烦的从内存模型开始说起:作为一般人需要了解到的,JVM的内存区域可以被分为:线程栈,堆,静态方法区(实际上还有更多功能的区域,并且这 ...
- 【java编程】ServiceLoader使用看这一篇就够了
转载:https://www.jianshu.com/p/7601ba434ff4 想必大家多多少少听过spi,具体的解释我就不多说了.但是它具体是怎么实现的呢?它的原理是什么呢?下面我就围绕这两个问 ...
- Java中的多线程=你只要看这一篇就够了
如果对什么是线程.什么是进程仍存有疑惑,请先Google之,因为这两个概念不在本文的范围之内. 用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现.说这个话其 ...
- [转帖]nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件
nginx学习,看这一篇就够了:下载.安装.使用:正向代理.反向代理.负载均衡.常用命令和配置文件 2019-10-09 15:53:47 冯insist 阅读数 7285 文章标签: nginx学习 ...
- 2019-5-25-win10-uwp-win2d-入门-看这一篇就够了
title author date CreateTime categories win10 uwp win2d 入门 看这一篇就够了 lindexi 2019-5-25 20:0:52 +0800 2 ...
- 鸿蒙应用程序Ability(能力)看这一篇就够
本节概述 什么是Ability Ability分类 Ability生命周期 Ability之间跳转 什么是Ability Ability意为能力,是HarmonyOS应用程序提供的抽象功能.在Andr ...
- windows server 2019 域控批量新增不用,只看这一篇就够了,别的不用看
windows server 2019 域控批量新增不用,只看这一篇就够了,别的不用看 1. 新建excel表格 A B C D E 姓 名 全名 登录名 密码 李 四 李四 李四 test123!@ ...
- 什么是 DevOps?看这一篇就够了!
本文作者:Daniel Hu 个人主页:https://www.danielhu.cn/ 目录 一.前因 二.记忆 三.他们说-- 3.1.Atlassian 回答"什么是 DevOps?& ...
随机推荐
- pyhon-高并发测试
使用gevent.对注册.接口进行200的并发量进行测试. #!/usr/bin/env python # -*- coding:utf-8 -*- #设置路径:Defualt Settings--- ...
- win10让人愤怒的磁盘占用100%问题
升级win10以后其他还好.但是系统经常响应非常非常慢,后来观察发现每次非常卡的时候我的磁盘占用就是100%的. 我是技嘉的B85主板. 1盘是128g的东芝SSD(GPT), 2盘是WD的3TB H ...
- [bzoj1416]神奇的口袋
容易发现操作任意次并不会改变每一个点的概率(因为每一个点加d的概率相同,期望与原数成比例),然后直接输出即可(要用高精度) 1 #include<bits/stdc++.h> 2 usin ...
- 力扣 - 剑指 Offer 42. 连续子数组的最大和
题目 剑指 Offer 42. 连续子数组的最大和 思路1(分析数组的规律) 我们可以从头到尾逐个累加,若之前的累加和小于0,那就从丢弃之前的累加,从当前开始重新累加,同时在遍历过程中比较记录下最大值 ...
- CF Edu Round 71
CF Edu Round 71 A There Are Two Types Of Burgers 贪心随便模拟一下 #include<iostream> #include<algor ...
- 洛谷 P6478 - [NOI Online #2 提高组] 游戏(二项式反演+树形 dp)
题面传送门 没错这就是我 boom0 的那场 NOIOL 的 T3 一年前,我在 NOIOL #2 的赛场上折戟沉沙,一年后,我从倒下的地方爬起. 我成功了,我不再是从前那个我了 我们首先假设 A 拥 ...
- 【GS文献】全基因组选择模型研究进展及展望
目录 1. GS概况 2. GS模型 1)直接法 GBLUP 直接法的模型改进 ①单随机效应 ②多随机效应 2)间接法 间接法模型 基于间接法的模型改进 3. GS模型比较 模型比较结论 4.问题及展 ...
- miRNA预测工具miRDeep-P2
之前讲过预测植物miRNA的一款软件miR-PREFER, 今天在介绍一款软件miRDeep-p2, 也叫miRDP2 安装 在此之前,应安装一下软件 Bowite, Bowtie2, Vienna ...
- Linux内网时钟同步问题(ntp和chrony)
我们都知道时钟同步可以使用外网服务器,在内网内不能连接外网的时候也需要时钟同步,那怎么进行呢? 选择内网的一台稳定的服务器作为时钟源,然后让其他机器都来同步这台机器即可. 注:其实ntp服务和chro ...
- web性能测试工具——http_load
http_load是一款基于Linux平台的web服务器性能测试工具,用于测试web服务器的吞吐量与负载,web页面的性能. http_load是基于linux.unix平台的一种性能测工具 它以并行 ...