当前位置: 首页 > backend >正文

为什么 Vite 速度比 Webpack 快?

一、webpack会先进行编译,再运行,vite会直接启动,再按需编译文件。

首先看两张图,可以清晰的看到,上面的图是webpack编译过的,而下面的图是vite直接使用工程内文件。
在这里插入图片描述
在这里插入图片描述

二、区别于Webpack先打包的方式,Vite利用ES Modules,将开发环境下的模块文件直接作为浏览器执行文件。

ES Modules是指通过export和import语句,允许再浏览器端导入导出模块。开发者实际上构建了一个依赖关系图,主流浏览器是直接支持的,vite正是利用这点。

三、Nodejs是毫秒级的,Go是纳秒级的,Webpack是基于Node.js构建的,Vite是基于esbuild预构建的,esbuild是Go语言编写的,打包速度Vite也更优。

四、在Webpack中,模块更新是需要重新编译的,而Vite只需要让浏览器重新请求。

综上所述,Vite比webpack更快的原因有4:

  1. 编译模式不同
  2. 对浏览器的利用不同(Vite利用了现代浏览器的esModules)
  3. 底层语言不同
  4. 热更新处理不同
http://www.xdnf.cn/news/3021.html

相关文章:

  • STM32单片机入门学习——第49节: [15-2] 读写内部FLASH读取芯片ID
  • 【行业特化篇3】制造业简历优化指南:技术参数与标准化流程的关键词植入艺术
  • 在Spark中通过jps命令看到的进程名,是哪个命令产生有什么作用
  • 亚远景-ASPICE认证:如何优化软件开发流程?
  • js 正则中的$0,1,2,3 是怎么用的
  • 解析表观遗传学的工具——ChIP-seq(二)
  • 博客打卡-小易喜欢的数列-动态规划
  • python数据分析(六):Pandas 多数据操作全面指南
  • JAVA 枚举类的ordinal用法
  • JavaScript中 说说你对闭包的理解?闭包使用场景?
  • Java练习8
  • GBDT算法原理及Python实现
  • 2024jxcpc D.Magic LCM (logn筛质因子)
  • 百度CarLife实现手机车机无缝互联
  • BT134-ASEMI机器人功率器件专用BT134
  • 告别碎片化!两大先进分块技术如何提升RAG的语义连贯性?
  • 【系统参数合法性校验】spring-boot-starter-validation
  • PowerBI更新后出现提示,无法正常使用,解决办法
  • JavaScript == 和 ===区别,分别在什么情况使用?
  • 角度(degrees)和弧度(radians)转换关系
  • Oracle OCP证书有效期是三年?
  • 5 个开源 MCP 服务器
  • 【MongoDB篇】MongoDB的集合操作!
  • 【angular19】入门基础教程(四):默认的css隔离作用域
  • 基于Java,SpringBoot,HTML水文水质监测预警系统设计
  • 【最新 MCP 战神手册 08】工具使用详解:实现 AI 行动
  • 动态图表 -- eg1
  • Femap许可分配和监控
  • 4月29日星期二今日早报简报微语报早读
  • 优化PCB Via Stub系列(1):一次学会利用层叠设计降低Via Stub损耗