如果能重来,你要选 Vite 还是 Webpack ?

持续创作,加速成长!这是我参与「日新计划 6 月更文挑战」的第4天,点击查看活动详情

大家好,我是晚天。

Webpack 的第一次发布是在 2013 年发布,长久以来是主流的前端打包工具。Vite 的第一次发布是在 2021 年,是近两年来前端打包工具中的后起gitlab之秀,重点解决 Webpacgithub永久回家地址k 在开发阶段的开发痛点。截止 2022.6,Webpack 的 Github Star 数 61.2k,Vite 的服务器价格 Github Star 数是 42.7k。虽然 Vite 刚刚发布 2 年,但是热度可见一斑。

下面我们来对 Webpack 和 Vite 的不同点进行比较,并且解释 Vite 之于 Webpack 性能优势来源于哪里?

Webpack

Webpack 是一个基于打包器的构建工具,同一个入口文件的代码会打包成一个 Bundle 文件。Webpack 长期来的一个痛点是对于giti轮胎大规模应用的应用启动和热更新速度很慢。

如果能重来,你要选 Vite 还是 Webpack ?

当文件发生变动时,整个 JavaScript Bundle 文件会被 WebpHTTPac服务器怎么搭建k 重新构建,这也是为什么使用 Webpack 的大规模应用在应用启动和热更新时速度很慢的原因。这给进行大规模json格式怎么打开 JavaScript 应用的开发者造成了很差的开发体验。

Webpack 如何工作?

Webpack 打包过程:

  • 从一个入口文件开始,基于代码文件中的所服务器租用importexport服务器地址require 构建依服务器价格赖树;
  • 编译 JS/CSS 等模块;
  • 使用算法排序、重写、连接代码;
  • 优化。

开发环境的 Webpack:

  • 打包所有代码;
  • 启动 webpack-dev-server 托管打包好的代码;
  • 启动 websocket 处HTTP理热更新 HMR。

应用规模越大,启动和热更新代码越慢。及时启动了热更新,每次代码变更也需要重新生产 Bun服务器系统dle 文件。

Vite

Vite 是旨服务器在提升开发者体验的下一代 JavaScript 构建工具,核心借助了浏览器的原生 ES Modules 和像 esbuild 这样的将代httpclient码编译成 native code 的打包工具。

Vite 主要有两方面组成:

  • 一个开发服务器,基于 ESM 提供丰富的内建能力,比如速度快到惊人的模块热更新(HMR);
  • 一套构建指令,使用 rollup 进行代码打包,且零配置即可输出用于生产环境的高度优化的静态代码。

Vithttp://www.baidu.come 的核心能http://192.168.1.1登录力和 webpack + webpack-json数据dgithub中文官网网页ev-server 相似,但是在开发者体验上有一些提升:

  • 无论项目大小有多大,启动应用都只需更少的时间;
  • 无论项目大小有多大,HMR(Hot Module Replacing)热更新都可以做到及时响应;
  • 按需编译;
  • 零配置,开箱即用;
  • Esbuild 能力带来的 Typescwebsocket使用教程ript/jsx 的原生支持。

大型的 JavaScript 项目在开发和生产环境有比较差的性能表现,往往是因为我们使用的构建工具没有充分做到并行处理、内存优化和缓存。

核心理念:Bundless 开发环境构建

浏览器的原生 ES Modules 能力允许在不将代码打包到json解析一起的情况下运行 JavaScript 应用。Vite的核心理念很简单,就是借giti轮胎助浏览器原生ESModules能力,服务器操作系统当浏览器发出请求时服务器租用多少钱一年,为浏览器按需提供ESModule文件,浏览器获json数据取ESModule文件会直接执行。

应用启动

Vite 将应用中的模块分为依赖和源码两类,分别进httpwatch行服务器启Git动时间的优化。

  • 依赖模块,开发过程中基本不会变化。Vite 对依赖采用了 esbuild 预构建的方式,esbuild 使用 Go 编写,并且比以 Java服务器是什么Script 编写的打包器预构建依赖快 10-100 倍;
  • 服务器是什么码模块,是用户自己开发的代码,会经常变动。

Vite 在浏览服务器内存和台式机内存区别http 302请求时按需转换并以原生 ESM 方式提供源码,让浏览器websocket和socket区别接管了打包程序的部分工作。

Vite 如何工github作?

Vite 通过原生 ES Modulegithubs 托管源代码,本质上是让浏览器来接管部分打包器的工作。Vite 只会在浏览器请求发生时,按需将源码转成 ES Modules 格式返回给浏览器,由浏览器加载并执行 ES Modules 文件。

如果能重来,你要选 Vite 还是 Webpack ?

热更新

在基于 Bundle 构建的构建器中,当一个文件变websocket服务器动时,重新构建整个 Buwebsocket协议ndle 文件是非常低效的,且随着应用规模的上升,构建速度会直线下降。

传统的构建器虽然提供了热更新的能力,websocket协议但是也会存在随着应用规模上升,热更新速度显著下降的问题。

Vite 基于 ESM 按需提供源码文件,当一个文件被编辑后http://192.168.1.1登录,Vite 只会重新编译并提供该文件。因此,无论项目规模多大,Vite 的热更新都可以保持快速更新。WebSocket

此外,Vite 合理利用浏览器缓存来加速页面加载,源码模websocket是什么块请求根据 304 Not Modified 进行协商缓存;依赖模块请求通过 Cache-Control:json是什么意思 max-age=31github中文官网网页536000,websocket服务器immutable 进行强缓存,因此一旦缓存,服务器租用不会再次请求。

生产环境仍需打包

在生产环境使用http 404 ESM 会存在大量额外网络请求http 404问题,因此生产环http 500境不太试用 ESM,最好的方式还是代码进行 tree-shaking、懒加载、和 cjsonobjecthunk 分隔等。

那么生产环境的服务器构建为什么不直接使用 esbuild,而是使用 rollup 呢?这是因为 esbuild 在代码分隔、css 处理等方面的功能仍在开发中,rollup 在应用打包方面更加的成熟且灵活。

性能提升

Vite 依托支持原生 ESM 模块的现代浏览器,极大的降低了应用的启动和重新构建时间。Vite 本质上是一个在开发环境为浏览器按需提供文件的 Web Server,这些文件websocket协议http 302含源码模块和在第一次运行时使用 esbuild 预构建的依赖模块。

Vite 和 Wejsonbpack 的主要不同在于开发环境下对于源码如何被托管以及支持哪种模块规范。

依赖预构建

Vite 在首次启动时,会进行依赖预构建。依赖预构建有两个目的:

  • CommonJs 和 UMD 的兼容性:开发阶段,Vigiticomfort是什么轮胎te 的 Dev Server 将所有代码视为原生 ES 模块。因此,Vite 必须将 CommonJS 或 UMD 发布的依赖项转为 ESM。
  • 性能:Vite 将有很多内部模块的依赖视为单个模块,以提升页面加载性能。比如,lodash-es 拥有超过 600 个内部模WebSocket块,当 import {debounce} from 'lodash-json格式es'; 时,浏websocket是什么览器会同时发起超过 600 个请求,并行请求过多json将会显著影响页面加载性能。因此预构建将 lodash-es 视为一个服务器内存条可以用在台式机上吗模块,浏览器只需要发起一个请求。

服务器内存和台式机内存区别

文件系统缓存

Vite 会将预构建的依赖缓存到 node_modules/.vite ,它根据几http 404个源决定是否需要重新运行预构建步骤:

  • package.json 中的 dependencies 列表;
  • 包管理的 lockfile,例如 package-lock.jsonyarn.lock 或者 pnpm-lock.yawebsocket服务器ml
  • 可能在 vite.config.js 相关字段中配置过的。

只有在git教程上述其中一项发生更改时,才需要重新运websocket和socket区别行预构建。

如果处于某些原因,你想要强制 Vite 重新构建依赖,你可以用 --服务器租用fo服务器内存条可以用在台式机上吗rce 命令选项启动开发服务器,或者手动删除 node_modules/.vite 目录。

浏览器缓存

解析后的依赖请求会以 HTTPmax-age=31536000,immutable 强缓存,以提高开发时的页面重载性能。如果你想通过本地编辑来调试依赖json怎么读项,可以:

  • 通过浏览器调试工具的 Network服务器怎么搭建 选项卡暂时禁用缓存;
  • 重启 Vite Dev Servjson是什么意思er,并添加 --force 命令以重新构建依赖;
  • 重新载入页面。

Typescript 原生支持

Vite 天github中文官网网页然支持引入 .t服务器是什么s 文件,单仅支持 .ts 文件的转译工作,并不执行任何类型检查。

Vite 使用 esbuild 将 TypeScript 转译到 Jawebsocket服务器vaScrijson是什么意思pt,约是 tsc 速度的 20-30 倍,同时 HMR 更新到浏览器的时间小于 50 ms。

对比

简单对 Webpack 和 Vite 进行一个对比:

Webpack

  • 支持的模块规范:ES Modules,CommonJS 和 AMD Modules;
  • Dev Server:通过 webpack-dev-serverhttp 302管打包好的模块;
  • 生产环境构建:webpack

Vite

  • 支持的模块规范:ES Modules;
  • Dev Se服务器价格rver:原生 ESwebsocket即时通讯 Modules;
  • 生产环境构建:Rollup

总结

由于浏览器原生 ES Modules 的支持,当浏览器发出请求时,Vite 可以在不将源码打包为一个 Bundlgiticomfort是什么轮胎e 文件的情况下,将源码文件转化为 ES Modules 文件之后返回给浏览器。这样 Vgitiite 的应用启动和热更新 HMR 时的速度都不会随着应用规模的增加而变慢。

参考资料

  • Vite Official Docs

  • Lightning Fast Builds with Vite

  • Is Vit服务器价格e Better than Webpack?

  • Understanding a Comparison: Webpack vs ViteJS

  • ComparingGit the New Generatio服务器租用多少钱一年n of Build Thttp协议ools

  • 聊聊 ESM、Bundlehttp://www.baidu.com 、Bundleless 、Vite服务器租用多少钱一年 、Snowpack

  • ES modugit教程les: A cartoon deep-dive

  • js打包时间缩短90%,bundleless生产环境实践总结

  • Webpacjson解析k 打包太慢?来试试 Bundleless 吧!

  • Is Webpack Packaging Too Slow? Try tgitlabhe Bundleless M服务器内存条可以用在台式机上吗ode

  • How Does Vite Work –json怎么读 A Compagit教程rison to Webpack

发表评论

提供最优质的资源集合

立即查看 了解详情