一、为什么要用vue3.0


1.核心代码进行了压缩,核心代码+composition API(合成函数):13.5KB,最小11.75kb
2.所有的runtime(运行时间):22.5kb(vue2是32kb)

二、vue3.0带来的变化

1.按需加载&组合api
vue2里面是使用生命周期的方法,结合着,data,props,computed,watch这一系列绑定在vue实例上的方法,来控制整个代码。但这样会带来一些问题,当代码非常冗长的时候,或者逻辑非常复杂的时候,组件是不可读的。虽然,filter,directive,mixins带来了一些便利和灵活,但没有解决在组件之前想要共用一些逻辑,又想要这些逻辑容易阅读和理解的问题。
2.TS支持,新增:Fragment、Teleport、Suspense
Fragment:碎片,解决必须写根节点的问题
Teleport:全局组件,比如:弹窗,alert,dialog……
Suspense:异步加载,有些组件需要异步取得某些组件返回的结果渲染的dom结构,Suspense可以在组件里面去异步调取其他组件
3.性能提升1.3~2x

三、按需加载

1.基础:virtual DOM(虚拟dom),响应式算法(必须要有的)
2.非常用功能,按需加载,根据自己需求
v-model
transition

四、compiler的原理

1.静态node不再作更新处理
2.静态绑定的class,id不再作更新处理
3.结合打包的hint(提示),进行更新分析

4.事件监听器cache缓存处理(cachehandlers)
有些可能会重复创建的组件,比如说在组件中去传递事件的时候, 这些其实是提升了一个等级,然后去把它缓存起来,这样,在重复创建组件的时候,方法不会重复实例化,这样就会优化内存的使用。
5.hoistStatic(静态提升)自动针对多静态节点进行优化,输出字符串
6.按需加载


静态node不会做更新处理,着重注意的是注释(hint)部分,当节点多了之后,会编译成一个静态字符串。

都是在前端完成不是服务器端完成的,这样的好处是提升了js的处理速度。着眼于需要处理的动态内容,提升性能。减少创建对象的数量,减少内存的占用。

五、compiler总结

1.virtua DOM机制调整
2.内存优化,更少的占用
3.按需加载,更灵活的组件化

vue3.0原理 —— complier相关推荐

  1. Vue3.0之双向绑定原理——Proxy

    了解代理模式 一个例子 作为一个单身钢铁直男程序员,小王最近逐渐喜欢上了前端小妹,不过呢,他又和前台小妹不熟,所以决定委托与前端小妹比较熟的UI小姐姐帮忙给自己搭桥引线.小王于是请UI小姐姐吃了一顿大 ...

  2. vue3.0实现原理

    vue3.0.js ------------------ function Vue(option){  this.$el = document.querySelector(option.el); // ...

  3. Vue3.0 备受热捧!2020 前端开发进阶必读

    你好,我是汤小洋. 前华为全栈工程师,南京大学软件工程硕士,拥有11年全栈开发及内部培训分享经验. 作为一名前端人,学习从不是一件容易的事,这是我一路走过来的真实感受."只要付出,就有收获& ...

  4. Vue最全知识点,面试必备(基础到进阶,覆盖vue3.0,持续更新整理,欢迎补充讨论)

    声明:本篇文章纯属笔记性文章,非整体原创,是对vue知识的整理,对自己有很大帮助才分享出来,参考文章传送:1.童欧巴对vue知识的整理 2.我是你的超级英雄对vue知识的整理 3.vue官网 基础篇 ...

  5. Vue3.0笔记(B站天禹老师)

    Vue3快速上手 1.Vue3简介 2020年9月18日,Vue.js发布3.0版本,代号:One Piece(海贼王) 耗时2年多.2600+次提交.30+个RFC.600+次PR.99位贡献者 g ...

  6. vue3.0导出excel带格式

    这个真的困扰了我整整一天,我尝试了xlxs file-saver两个组件的版本,怎么搞都不行 先不说vue3.0 不能import进来,只能require('xlxs'),require('file- ...

  7. 【Vue系列】Vue3.0知识点汇总整理

    目录 一.Vue3简介 1.Vue3带来了什么? 二.创建Vue3工程 1.使用vue-cli创建 2.使用vite创建 补充:分析Vue3的工程结构 三.常用Composition API 1.初识 ...

  8. vue3.0初体验(例子解读reactive响应式)

    目录 准备 vue3 reactive原理例子重点讲解 vue3 reactive原理例子完整代码 准备: 下载vue-next 安装依赖 npm install 核心部分package,里面的vue ...

  9. 【Vue学习笔记】尚硅谷Vue2.0+Vue3.0全套教程丨vue.js从入门到精通

    尚硅谷Vue2.0+Vue3.0全套教程丨vue.js从入门到精通 1.Vue核心部分 1.1 Vue简介 1.1.1 Vue是什么? Vue是一套用于构建用户界面的渐进式JavaScript框架. ...

最新文章

  1. vivado VIO (virtual input output)虚拟IO的使用
  2. 【error】scripts/basic/fixdep: Syntax error: ( unexpected
  3. 大四实习有点晚[转载]
  4. external libraries里没有maven包_Maven企业实战系列(三):彻底看懂maven的体系结构...
  5. java三目运算符嵌套_替代JS中的嵌套三元运算符
  6. springboot ElasticSearch 简单的全文检索高亮
  7. java mongodb 插入数据_mongoDB 插入数据 用java实现
  8. Android笔记: 在Eclipse环境下使用Genymotion模拟器
  9. ActiveMQ—Windows操作系统中如何安装启动ActiveMQ
  10. MFC获取指针.doc
  11. 最好用AI抠图的软件,方便你,我,他。
  12. python微积分求面积_用Python学微积分(微积分应用)
  13. 二叉树入门OJ—递归思想练习
  14. 富士施乐Fuji Xerox DocuPrint P158 b 驱动
  15. 有哪些计算机法人快捷键,tras企业版操作说明.doc-广东省国家税务局.doc
  16. CentOS 7 出现 a problem has occured and the system can‘t recover 解决办法:组合键进入命令行进行修复
  17. 2019前端书籍推荐,前端PDF书籍,前端书籍下载
  18. java sdk他edk de区别_EDK笔记——自定义IP核
  19. 创业起步的十大准备步骤
  20. 关于MDL的一些事(2)

热门文章

  1. oracle笛卡尔积
  2. wincc打不开项目 本地服务器不可用,打开提示启动本地服务器后,出现:cannot open wincc project。。。...
  3. 刚刚,2022年中国大学生源质量排名发布
  4. android编码:国标色彩标准名称和色值
  5. 绩效管理方式的升级,极有可能在2023年让组织绩效提升5%-10%
  6. Pythhon消消乐小游戏
  7. Flask Web开发--1.多租户SPC质量分析系统设计
  8. GBase 8c文件系统级别备份
  9. 萤石“小步快走”,跨进智能家居生态圈
  10. python调用js批量爆破账号密码