Skip to content

第1章 为什么需要理解 Vite

"工具的价值不在于它做了什么,而在于它让你不再需要思考什么。"

本章要点

  • 理解前端构建工具从 Webpack 到 Vite 的演进动力
  • 掌握 Vite 的两大核心创新:原生 ESM 开发服务器与 Rolldown 构建引擎
  • 明确深入源码的价值:从"会用"到"理解为什么这样设计"
  • 建立全书的阅读路线图

1.1 前端构建工具的三次变革

前端构建工具的演进史,本质上是一部开发体验与生产性能的博弈史

第一代:打包一切(Webpack 时代)

Webpack 的核心理念是"万物皆模块"——JS、CSS、图片、字体,所有资源都通过 loader 转换为 JavaScript 模块,最终打包成 bundle。这在 2015 年是革命性的,但随着项目规模增长,问题浮现了:

  • 冷启动慢:一个中型项目(5000 个模块)的 webpack-dev-server 启动需要 30-60 秒
  • 热更新慢:修改一个文件后,需要重新构建整个 chunk 图
  • 配置复杂webpack.config.js 动辄数百行,loader/plugin 的组合爆炸

第二代:编译加速(esbuild/swc 时代)

esbuild(Go)和 swc(Rust)用系统语言重写了 JavaScript 编译器,将转换速度提升了 10-100 倍。但它们解决的是编译速度问题,而不是架构问题——开发服务器仍然需要先打包再服务。

第三代:按需服务(Vite 时代)

Vite 的突破不在于更快的编译器,而在于架构创新

开发阶段,Vite 利用浏览器原生 ESM 支持,不打包、不构建,浏览器请求哪个模块就实时转换哪个模块。这让冷启动从"分钟级"降到"毫秒级"。

生产阶段,Vite 使用 Rolldown(Rust 编写的 Rollup 兼容打包器)进行优化构建,兼顾性能与产物质量。

1.2 Vite 的核心设计哲学

开发与生产的分离

这是 Vite 最根本的架构决策:开发和生产使用完全不同的策略。开发追求速度(原生 ESM + 按需转换),生产追求质量(Rolldown + 优化)。

插件优先

Vite 的核心非常小——大部分功能(CSS 处理、TypeScript 编译、HTML 转换、资源处理)都通过内置插件实现。用户插件和内置插件使用完全相同的 Hook 接口,没有特权 API。

约定优于配置

零配置即可处理 TypeScript、JSX、CSS Modules、静态资源。只有当你需要定制时才需要配置。

1.3 为什么要读 Vite 源码

超越文档的理解

文档告诉你 import.meta.hot.accept() 可以注册 HMR 回调,但不会告诉你:

  • HMR 更新如何从文件变更传播到浏览器
  • 模块图的"软失效"和"硬失效"有什么区别
  • 循环依赖在 HMR 中如何处理

插件开发的底层知识

如果你要开发 Vite 插件,理解内置插件的实现会帮你:

  • 知道每个 Hook 的最佳使用时机
  • 避免与内置插件冲突
  • 利用内部 API 实现更强大的功能

可迁移的架构模式

Vite 源码中有大量可迁移到其他项目的设计模式:

  • 中间件栈的请求处理管线
  • 基于图的依赖追踪与失效传播
  • 增量式依赖发现与预构建
  • 多环境隔离架构

1.4 本书的组织方式

  1. 架构层(第1-2章):建立全景认知
  2. 基础设施层(第3-4章):配置系统与插件机制
  3. 开发服务器层(第5-8章):服务器、模块图、HMR、预构建
  4. 转换管线层(第9-12章):JS/CSS/HTML/资源的处理
  5. 构建层(第13-14章):Rolldown 集成与产物优化
  6. 高级特性层(第15-17章):SSR、Environment API、Worker
  7. 总结层(第18章):可迁移的设计模式

每一章都会大量使用 Mermaid 图表来可视化数据流、状态机和架构关系,帮助你建立清晰的心智模型。

让我们开始吧。

基于 VitePress 构建