首页 > 其他分享 >你知道Vue 3.0中Treeshaking特性吗?

你知道Vue 3.0中Treeshaking特性吗?

时间:2023-09-30 21:03:44浏览次数:45  
标签:Vue Tree 组件 构建 3.0 Treeshaking shaking


介绍

Vue 3.0引入了Tree-shaking特性,旨在优化构建过程并减小最终生成的代码大小。Tree-shaking是一种在构建时移除未使用代码的技术,通过分析模块的依赖关系,将没有被引用的部分从最终的打包文件中排除掉。这可以大大减少应用的体积,提高性能。

举个通俗一点的例子:
当我们开发一个应用程序时,会使用各种工具和库来帮助我们构建功能。有时候,这些工具和库可能比我们实际用到的东西要大很多,就像买了一个大箱子,但只用了里面一小部分。Tree-shaking 就像是一个魔法,可以帮助我们在箱子里只留下我们需要的东西,把其他不需要的东西都自动丢掉,从而减小了箱子的大小。

在Vue 3.0中,这个魔法的一部分让我们可以只使用应用中需要的部分,而不需要加载整个东西。比如,如果你只需要一个小按钮,这个魔法会让你只拿出按钮,而不是整个工具箱。这样,你的应用会更快,更节省空间。而且,这个魔法还会自动帮你整理东西,把你没有用到的东西都扔掉,就像自动把箱子里多余的东西清理出去一样。

这样做的好处是,你的应用会更轻便,加载更快,用户体验更好。就像只带着一个小背包去旅行,而不是拖着一个大行李箱一样。所以,Vue 3.0中的Tree-shaking就是让我们的应用更高效,更省资源的一种方法。

在Vue 3.0中,Tree-shaking的特性主要包括:

  1. 按需加载组件: Vue 3.0的模块化系统允许你按需加载组件,只引入应用所需的部分。这样可以避免将整个Vue库全部打包进应用中,从而减小了代码体积。
import { createApp } from 'vue';
import { Button, Input } from 'ant-design-vue';

const app = createApp();
app.use(Button);
app.use(Input);
app.mount('#app');
  1. 编译时模板优化: Vue 3.0的编译器会将模板中未被使用的部分自动优化掉。这意味着如果你的模板中有未使用的元素或指令,它们将不会出现在最终的渲染函数中,从而减少了代码的大小。
  2. Tree-shakable特性: Vue 3.0的内部结构和代码组织被设计为支持Tree-shaking。这意味着当你只使用部分功能或组件时,未使用的代码将被自动排除,从而产生更小的包。

举个例子,假设你只需要在应用中使用Vue的reactivity特性(响应式系统),你可以这样导入:

import { reactive, watch } from 'vue';

在这种情况下,只有与reactivity相关的代码会被打包进最终的应用程序中,其他部分将被排除。这就是Vue 3.0中Tree-shaking特性的作用之一,可以根据应用的需求来裁剪和优化代码,减少最终生成的代码大小。

为何vue2不支持

Vue 2.x 的设计和构建是在 ES5 时代完成的,当时的 JavaScript 模块系统和构建工具并没有像现在这样成熟。在 Vue 2.x 中,大多数功能和组件是以对象的形式暴露出来的,而且整个库的组织方式和设计没有针对 Tree-shaking 这种高级的代码优化进行特别的优化。这导致在 Vue 2.x 中难以实现有效的 Tree-shaking。

Vue 2.x 中没有很好的支持 Tree-shaking 的原因主要有以下几点:

  1. ES5 构建: Vue 2.x 的主要构建版本是基于 ES5 的,这个时候的 JavaScript 模块系统还没有像现在的 ES6 模块系统一样完善,因此不同于现代的模块系统,它不太支持按需引入。
  2. 组件导入方式: 在 Vue 2.x 中,大部分组件是通过直接引入 Vue 对象的属性来使用的,这导致整个 Vue 对象以及所有的属性都会被包含进最终的构建中,无法精确地按需引入。
  3. 组件间关系: Vue 2.x 的组件在定义和使用时的关系较为复杂,可能会造成不同组件之间的依赖关系和引用关系,这也会影响 Tree-shaking 的效果。

Vue 3.x 在设计和构建时更加注重了 Tree-shaking 的支持,使用了更先进的 JavaScript 模块系统(ES6+),采用了更灵活的组件导入方式,同时也在内部进行了优化,以便于更好地支持按需引入和 Tree-shaking。这使得 Vue 3.x 能够更有效地利用 Tree-shaking 技术,从而减小最终构建的大小。

最近学习到vue3中的Treeshaking,顺便记录一下,如有理解不当欢迎指出。



标签:Vue,Tree,组件,构建,3.0,Treeshaking,shaking
From: https://blog.51cto.com/u_14196886/7664963

相关文章

  • Vue双向数据绑定原理-中
    defineProperty方法defineProperty除了可以动态修改/新增对象的属性以外,还可以在修改/新增的时候给该属性添加get/set方法,从而实现数据劫持。definePropertyget/set方法特点只要通过defineProperty给某个属性添加了get/set方法,那么以后只要获取这个属性的值就会自动调用g......
  • 【RuoYi移动端】uni-app中通过vuex的store来实现全局变量的修改和读取
    一、在store文件中新建csjVar.js文件constcsjVar={csjMess:[{aaa:"ok"},{bbb:"no"}]}exportdefaultcsjVar二、修改store文件中新建index.js文件importVuefrom'vue'importVuexfrom'vuex'importuserfrom'@/store/modules/user�......
  • vue:自定义validator/验证规则([email protected])
    一,官方文档地址:https://element-plus.gitee.io/zh-CN/component/form.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E6%A0%A1%E9%AA%8C%E8%A7%84%E5%88%99二,js代码:123456789101112131415161718192021222324252627282930313233343536373......
  • vue:el-table在resize时报错([email protected])
    一,报错信息:Uncaughtruntimeerrors:×ERRORResizeObserverloopcompletedwithundeliverednotifications.athandleError(webpack-internal:///./node_modules/webpack-dev-server/client/overlay.js:299:58)ateval(webpack-internal:///./node_modules/webpa......
  • vue处理响应式的思路
    首先看如下js代码leta='张三'console.log(a)//当前页面展示的是张三a='李四'首先页面刚开始渲染的时候数据a为张三,之后将a修改为了李四以后页面不会发生改变,但是数据已经修改了,vue为了解决这一问题,采用响应式的办法。通过对象的defineProperty方法,在回调函数中监听;......
  • Vue自定义指令
    定义指令全局定义//指令名称为:mydirec1Vue.directive('mydirec1',{//指令配置})//指令名称为:mydirec2Vue.directive('mydirec2',{//指令配置})之后,所有的组件均可以使用mydirec1和mydirec2指令<template><!--某个组件代码--><div><MyCompv-......
  • vue_error_Runtime directive used on component with non-element root node. The di
    翻译:'运行时指令,用于非元素根节点的组件。这些指令将无法发挥预期的作用';这个错误发生在我将v-show放在自定义组件上时,我想是因为自定义组件在渲染时会被自定义组件的内部元素替换,因此设置是无效的解决:在自定义组件外加一个div,把v-show写在div上......
  • 基于vue和element-ui开发仿桌面文件夹组件
    ......
  • vue前端框架ruoyi介绍
    Ruoyi是一个基于Vue.js和SpringBoot框架构建的开源前后端分离的企业级快速开发平台。它遵循了前后端分离的架构模式,将前端和后端进行解耦,使得系统更加灵活、可扩展和易于维护。Ruoyi的前端部分采用了Vue.js框架,这是一个流行的JavaScript前端框架,专注于构建用户界面。Vue......
  • 2023.09.28
    给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。 示例1:输入:s="()"输出:true示例 2:输入:s="()[]{}"输出:t......