从头看 vite 源码 - 调试

前言

准备开一个系列,记录学习 vite 源码的过程。

首先准备的是 vite 源码调试环境。

如何调试

vite 对调试的支持非常好。这里看的 vite 源码版本为:7.1.7,打包工具为 rolldown

首先 clone 项目。

bash 复制代码
git clone https://github.com/vitejs/vite.git

vite 采用 monorepo 架构,使用 pnpm 作为包管理工具,这个版本使用 rolldown 作为打包工具。

在根目录下,有两个文件夹:

  • packages
  • playground

packages 中存放着 vite 相关的包,包括源代码。

playground 中则是存放项目示例。

先说答案,如何调试。

  1. 进入 packages/vite
  2. 执行 npm run dev
  3. 进入 playground 文件夹,找到一个感兴趣的项目
  4. 进入并执行 pnpm run debug
  5. 打开谷歌浏览器
  6. 进入 chrome://inspect/#devices
  7. 找到 localhost:9229 (v22.19.0) 并点击 inspect 按钮
  8. 弹出调试窗口

说明

2. 执行 npm run dev

这一步主要是执行 npm run dev 命令。这个命令其实是 premove dist && pnpm build-bundle -w -s

可以看到这个命令由两部分组成,一部分删除 dist 文件夹。后面一部分则是使用 watch 模式打包。

4. 进入并执行 pnpm run debug

这个命令其实是"node --inspect-brk ../../packages/vite/bin/vite",主要作用是进入调试模式。

node --inspect-brkNode.js 的调试参数。

  • --inspect

    启动 Node inspector(调试协议),监听默认端口 9229,允许你用 Chrome DevTools / VS Code attach 调试。

  • --inspect-brk

    --inspect 的区别是:在程序的第一行就暂停,等你连接上调试器后再继续执行。

同时在 vite 脚手架代码中也对调试命令做了处理。

js 复制代码
const inspector = await import('node:inspector').then((r) => r.default)
  const session = (global.__vite_profile_session = new inspector.Session())
  session.connect()
  session.post('Profiler.enable', () => {
    session.post('Profiler.start', start)
  })

5. 打开谷歌浏览器

8. 弹出调试窗口

相关推荐
excel1 分钟前
Vue 模板编译中的 srcset 机制详解:从 HTML 语义到编译器实现
前端
excel1 分钟前
🌐 从 Map 到 LRUCache:构建智能缓存工厂函数
前端
excel2 分钟前
Vue 模板编译中的资源路径转换:transformSrcset 深度解析
前端
excel10 分钟前
Vue 工具函数源码解析:URL 解析与分类逻辑详解
前端
excel13 分钟前
Vue SFC 样式预处理器(Style Preprocessor)源码解析
前端
excel14 分钟前
深度解析:Vue Scoped 样式编译原理 —— vue-sfc-scoped 插件源码详解
前端
excel16 分钟前
Vue SFC Trim 插件源码解析:自动清理多余空白的 PostCSS 实现
前端
excel20 分钟前
Vue SFC 样式变量机制源码深度解析:cssVarsPlugin 与编译流程
前端
excel22 分钟前
🧩 Vue 编译工具中的实用函数模块解析
前端
excel26 分钟前
🧩 深入剖析 Vue 编译器中的 TypeScript 类型系统(第五篇)
前端