Vue3.0的优化总结


Posted in Javascript onOctober 16, 2020

1.源码优化:

a.使用monorepo来管理源码

  • Vue.js 2.x 的源码托管在 src 目录,然后依据功能拆分出了 compiler(模板编译的相关代码)、core(与平台无关的通用运行时代码)、platforms(平台专有代码)、server(服务端渲染的相关代码)、sfc(.vue 单文件解析相关代码)、shared(共享工具代码)等目录。
  • Vue.js 3.0,整个源码是通过 monorepo 的方式维护的,根据功能将不同的模块拆分到 packages 目录下面不同的子目录中,每个 package 有各自的 API、类型定义和测试。

b.使用Typescript来开发源码

  • Vue.js 2.x 选用 Flow 做类型检查,来避免一些因类型问题导致的错误,但是 Flow 对于一些复杂场景类型的检查,支持得并不好。
  • Vue.js 3.0 抛弃了 Flow ,使用 TypeScript 重构了整个项目。 TypeScript 提供了更好的类型检查,能支持复杂的类型推导;由于源码就使用 TypeScript 编写,也省去了单独维护 d.ts 文件的麻烦。

2.性能优化:

a.引入tree-shaking的技术

  • tree-shaking 依赖 ES2015 模块语法的静态结构(即 import 和 export),通过编译阶段的静态分析,找到没有引入的模块并打上标记。像我们在项目中没有引入 Transition、KeepAlive 等不常用的组件,那么它们对应的代码就不会打包进去。

b.移除了一些冷门的feature

  • Vue.js 3.0 兼容了 Vue.js 2.x 绝大部分的api,但还是移除了一些比较冷门的feature:如 keyCode 支持作为 v-on 的修饰符、$on,$off 和 $once 实例方法、filter过滤、内联模板等。

3.响应式实现优化:

a.改用proxy api做数据劫持

  • Vue.js 2.x 内部是通过 Object.defineProperty 这个 API 去劫持数据的 getter 和 setter 来实现响应式的。这个 API 有一些缺陷,它必须预先知道要拦截的 key 是什么,所以它并不能检测对象属性的添加和删除。
  • Vue.js 3.0 使用了 Proxy API 做数据劫持,它劫持的是整个对象,自然对于对象的属性的增加和删除都能检测到。

b.响应式是惰性的

  • 在 Vue.js 2.x 中,对于一个深层属性嵌套的对象,要劫持它内部深层次的变化,就需要递归遍历这个对象,执行 Object.defineProperty 把每一层对象数据都变成响应式的,这无疑会有很大的性能消耗。
  • 在 Vue.js 3.0 中,使用 Proxy API 并不能监听到对象内部深层次的属性变化,因此它的处理方式是在 getter 中去递归响应式,这样的好处是真正访问到的内部属性才会变成响应式,简单的可以说是按需实现响应式,就没有那么大的性能消耗。

4.编译优化:

a.生成block tree

  • Vue.js 2.x 的数据更新并触发重新渲染的粒度是组件级的,单个组件内部需要遍历该组件的整个 vnode 树。
  • Vue.js 3.0 做到了通过编译阶段对静态模板的分析,编译生成了 Block tree。Block tree 是一个将模版基于动态节点指令切割的嵌套区块,每个区块内部的节点结构是固定的。每个区块只需要追踪自身包含的动态节点。

b.slot编译优化

  • Vue.js 2.x 中,如果有一个组件传入了slot,那么每次父组件更新的时候,会强制使子组件update,造成性能的浪费。
  • Vue.js 3.0 优化了slot的生成,使得非动态slot中属性的更新只会触发子组件的更新。动态slot指的是在slot上面使用v-if,v-for,动态slot名字等会导致slot产生运行时动态变化但是又无法被子组件track的操作。

c.diff算法优化

语法api优化

a.优化逻辑组织

  • 使用 Vue.js 2.x 编写组件本质就是在编写一个“包含了描述组件选项的对象”,可以把它称为 Options API。我们按照 data、props、methods、computed 这些不同的选项来书写对应的代码。这种方式对于小型的组件可能代码还能一目了然,但对于大型组件要修改一个逻辑点,可能就需要在单个文件中不断上下切换和寻找逻辑代码。
  • Vue.js 3.0 提供了一种新的 API:Composition API,它有一个很好的机制去解决这样的问题,就是将某个逻辑关注点相关的代码全都放在一个函数里,这样在修改一个逻辑时,只需要改那一块的代码了。

b.优化逻辑复用

  • 在 Vue.js 2.x 中,我们一般会用 mixins 去复用逻辑。当抽离并引用了大量的mixins,你就会发现两个不可避免的问题:命名冲突和数据来源不清晰。
  • Vue.js 3.0 设计的 Composition API,在逻辑复用方面就会很有优势了。

以上就是Vue3.0的优化总结的详细内容,更多关于Vue3.0的优化详解的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
FireFox JavaScript全局Event对象
Jun 14 Javascript
如何使Chrome控制台支持多行js模式——意外发现
Jun 13 Javascript
禁用Enter键表单自动提交实现代码
May 22 Javascript
jquery库文件略庞大用纯js替换jquery的方法
Aug 12 Javascript
JavaScript插件化开发教程 (二)
Jan 27 Javascript
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
Nov 25 Javascript
详解JS构造函数中this和return
Sep 16 Javascript
基于vue2实现上拉加载功能
Nov 28 Javascript
vue.js使用v-model指令实现的数据双向绑定功能示例
May 22 Javascript
浅析vue中的MVVM实现原理
Mar 04 Javascript
vue实现购物车列表
Jun 30 Javascript
如何通过JS实现日历简单算法
Oct 14 Javascript
JavaScript通如何过RGraph实现动态仪表盘
Oct 15 #Javascript
利用js实现简易红绿灯
Oct 15 #Javascript
关于Node.js中频繁修改代码重启服务器的问题
Oct 15 #Javascript
JS如何操作DOM基于表格动态展示数据
Oct 15 #Javascript
Node 使用express-http-proxy 做api网关的实现
Oct 15 #Javascript
springboot+vue+对接支付宝接口+二维码扫描支付功能(沙箱环境)
Oct 15 #Javascript
angular共享依赖的解决方案分享
Oct 15 #Javascript
You might like
thinkphp学习笔记之多表查询
2014/07/28 PHP
PHP保存带BOM文件的方法
2015/02/12 PHP
php上传图片客户端和服务器端实现方法
2015/03/30 PHP
PHP读取文件的常见几种方法
2016/11/03 PHP
PHP编程计算文件或数组中单词出现频率的方法
2017/05/22 PHP
laravel5.6实现数值转换
2019/10/23 PHP
JQuery 无废话系列教程(二) jquery实战篇上
2009/06/23 Javascript
JS面向对象编程浅析
2011/08/28 Javascript
jquery怎样实现ajax联动框(一)
2013/03/08 Javascript
js 自制滚动条的小例子
2013/03/16 Javascript
使用js检测浏览器是否支持html5中的video标签的方法
2014/03/12 Javascript
深入理解javascript的执行顺序
2014/04/04 Javascript
js中的caller和callee属性介绍和例子
2014/06/07 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
2014/11/28 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
vue实现文章内容过长点击阅读全文功能的实例
2017/12/28 Javascript
AngularJS与后端php的数据交互方法
2018/08/13 Javascript
Javascript读取上传文件内容/类型/字节数
2019/04/30 Javascript
详解JavaScript自定义函数
2020/07/29 Javascript
vue打包通过image-webpack-loader插件对图片压缩优化操作
2020/11/12 Javascript
如何正确解决VuePress本地访问出现资源报错404的问题
2020/12/03 Vue.js
pygame实现俄罗斯方块游戏(AI篇1)
2019/10/29 Python
Python的in,is和id函数代码实例
2020/04/18 Python
keras 如何保存最佳的训练模型
2020/05/25 Python
详解Django ORM引发的数据库N+1性能问题
2020/10/12 Python
Opencv 图片的OCR识别的实战示例
2021/03/02 Python
HTML5探秘:用requestAnimationFrame优化Web动画
2018/06/03 HTML / CSS
HTML5 Canvas+JS控制电脑或手机上的摄像头实例
2014/05/03 HTML / CSS
HolidayLettings英国:预订最好的度假公寓、别墅和自助式住宿
2019/08/27 全球购物
2014年重阳节敬老活动方案
2014/09/16 职场文书
群众路线四风问题整改措施
2014/09/27 职场文书
合伙购房协议样本
2014/10/06 职场文书
2015年乡镇食品安全工作总结
2015/10/22 职场文书
2016十一国庆节慰问信
2015/12/01 职场文书
Feign调用传输文件异常的解决
2021/06/24 Java/Android
MySQL8.0升级的踩坑历险记
2021/11/01 MySQL