Vue3源码系列-Vscode调试源码

本系列文章参考的vue源码commit号是6021d0253e36b35d07d231b9ed36f95e286035be,版本号是3.3.6,以后如果出现vue4/vue5,本系列可能不适合阅读
本篇主要讲解如何调试源码,以及编写一个可运行的简单demo

相关资料:

  1. vue3文档
  2. vue3源码地址
  3. pnpm是什么
  4. pnpm多包管理
  5. esbuild是什么

启动服务

下载源码,默认main分支 运行以下命令下载依赖

shell 复制代码
pnpm i

运行以下命令,会运行scripts/dev.js这个文件

shell 复制代码
npm run dev

打开dev.js阅读,会发现该文件是用来启动esbuild的程序,通过传入入口文件位置/启动sourceMap(启动调试的重要条件)等参数启动esbuild程序进行打包,最后会运行一个监听器,通过监听src中的ts文件变化重新打包

运行以下命令,启动一个server,打开这个地址就会打开packages/vue/examples/classic/todomvc.html页面的内容,第一步就大功告成了🎉

shell 复制代码
npm run serve

进行调试

在.vscode文件夹添加launch.json,添加如下内容

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Launch Chrome",
      "request": "launch",
      "type": "chrome",
      "url": "http://localhost:3000",
      "webRoot": "${workspaceFolder}"
    }
  ]
}

packages/vue/examples/classic添加一个最简单的Vue程序demo.html,添加如下内容

html 复制代码
<script src="../../dist/vue.global.js"></script>

<div id="app">
  <h1>---{{a}}---</h1>
</div>

<script>
  Vue.createApp({
    data: () => {
      return {
        a: 122
      }
    }
  }).mount('#app')
</script>

保存文件之后按F5,vscode会打开一个新浏览器窗口

往浏览器输入地址 这就是我们刚才编写的代码呈现的页面

点击代码行数左边空白处 刷新浏览器就可以看到

点击右上角箭头就可以调试代码每一步🎉

相关推荐
亚空间仓鼠几秒前
Ansible之Playbook(三):变量应用
java·前端·ansible
invicinble4 分钟前
前端技术栈整理
前端
前端那点事6 分钟前
前端必看!console 调试不只有 log,这 8 个技巧省一半调试时间
vue.js
倾颜10 分钟前
pnpm monorepo 下,如何把 Next.js 应用里的稳定内核拆成内部 workspace 包
前端·react.js·next.js
念格14 分钟前
Flutter 仿微信输入框最佳实践:自适应高度 + 超行数智能切换全屏
前端·flutter
GISer_Jing15 分钟前
前端图片、动图与动画全解析(含PNG/APNG/Lottie/GIF/Canvas/WebGL/WebGPU)
前端·3d·动画·webgl
OpenTiny社区16 分钟前
多端开发头疼?TinyVue 3.30 一招搞定,AI还帮你写代码!
前端·vue.js·github
ZHENGZJM24 分钟前
前端认证状态管理与路由守卫
前端·状态模式
凌览34 分钟前
Claude半个月崩7次!算力不够自己造,强制实名制封
前端·后端
sTone873751 小时前
跨端框架通信机制全解析:从 URL Schema 到 JSI 到 Platform Channel
android·前端