怎么在VS Code 调试vue3 源码

总结一下怎么在VS Code 调试vue3 源码

  • 克隆vue3源码到本地
  • 在源码根目录安装依赖 把项目跑起来 生成packages/vue/dist/vue.global.js文件
  • 在packages/vue/examples/ 下随便找个文件 打上断点
  • 安装Live Server插件 把我们打上断点的文件在浏览器打开
  • 在.vscode文件夹下配置launch.json
  • 点击VS Code的Run and Debug图标 就可以进入了

我们开始吧~

克隆vue3源码到本地

去Github克隆源码,克隆后我们用VS Code打开。

bash 复制代码
git clone https://github.com/vuejs/core
在源码根目录安装依赖 把项目跑起来
bash 复制代码
pnpm i

如果puppeteer没安装成功 可能要多试几次 我用的pnpm 后面重新安装 那些依赖全部可以复用(reused)

把项目跑起来

bash 复制代码
npm/pnpm run dev

会生成packages/vue/dist/vue.global.js

在packages/vue/examples/ 下随便找个文件 打上断点

我们找packages/vue/examples/classic/commits.html 在如图位置打上断点

commits.html 这个文件引入了我们刚才构建出来的vue.global.js文件,所以打断点能进入对应的源码

html 复制代码
<script src="../../dist/vue.global.js"></script>
安装Live Server插件 把我们打上断点的文件在浏览器打开

安装好插件后,打开文件的上下文菜单 可以看到Open with Live Server

这样我们就可以打开我们的classic/commits.html 文件了 是用服务器打开的

在.vscode文件夹下配置launch.json

注意这里的URL是我们的要调试URL路径

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {"type":"node","request":"launch","name":"Run parser","runtimeExecutable":"parser","cwd":"${workspaceFolder}/packages/reactivity-transform/node_modules/@vue/compiler-core","args":[]},
    {
      "type": "chrome",
      "request": "launch",
      "name": "调试Vue源码",
      "url": "http://localhost:5500/packages/vue/examples/classic/commits.html",
      "webRoot": "${workspaceFolder}",
      "sourceMaps": true,
      "sourceMapPathOverrides": {
        "webpack:///./*": "${webRoot}/*",
        "webpack:///packages/*": "${webRoot}/packages/*",
        "*": "${webRoot}/*"
      },
      "skipFiles": [
        "<node_internals>/**"
      ]
    }
  ]
}
点击VS Code的Run and Debug图标

点击Run and Debug图标, 选择调试Vue源码(就是我们配置launch.json里面配置的name)

看到commits.html 进入我们打的断点了,可以看到进入mount方法这里

我们点击Step Into

就进入app.mount方法的源码了(精准的进入 不会走vite 对应的第三方包 一大堆最后才到对应的源码)

一个小贴士

在VS Code有一个debug console, 如果我们想打印出来具体传参,我们可以利用这个窗口

相关推荐
用户831348593069811 分钟前
Cesium实现雾气效果:按钮一键控制打开/关闭雾气效果,滑块拖动实时控制雾气浓度
vue.js·cesium
壹方秘境27 分钟前
ApiCatcher支持抓包HTTP传输大文件的实现原理分享
前端·后端·客户端
一份执念38 分钟前
uni-app项目 (vue+vite + uni-UI)中引入umd格式JS文件,微信小程序中导入报错处理方案
前端·uni-app·echarts
ClouGence1 小时前
2026 年自动化测试工具选型指南:8 款主流工具对比
前端·测试
lichenyang4531 小时前
为什么需要双线程通信、JavaScriptProxy 和 runJavaScript 分别干什么
前端
以和为贵2 小时前
前端也能搞懂 RAG:用 JS 手写一条最小检索增强链路
前端·人工智能·面试
风止何安啊2 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
牧艺2 小时前
用 Next.js + React Three Fiber 打造 3D 快递仓储可视化
前端·three.js
锋行天下3 小时前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架
光影少年3 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js