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

相关推荐
kyriewen1 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
小和尚同志1 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.01 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕2 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@2 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#3 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar3 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_471383034 小时前
Taro-02-页面路由
前端·taro
星栈独行4 小时前
Makepad 应用如何读文件、调接口、保存数据
前端·程序人生·ui·rust·github
IT_陈寒4 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端