从头看 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. 弹出调试窗口

相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea5 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd6 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌7 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈7 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫7 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝7 小时前
svg图片
前端·css·学习·html·css3
王夏奇8 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰8 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong239 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习