如何调试Vue3源码?

摘要

最近想系统学习一下vue3的源代码,本篇内容记录和分享一下如何调试vue3的源代码。

1. 下载源代码

1.1 github下载

想获取vue3的源码,需要直接从github上vue3的仓库获取,vue3github源码地址为:

注意,vue3的源码是在这个 core目录下,一些同学别一直找目录为vue3的文件夹,那是找不到的哈。

1.2 码云(gitee下载)

github虽好,但是对于国内用户,总还是有点敌意,访问的时候经常进不去,或者很慢,我在公司访问github时好好的,但在家就死活进不去,使用了代理也一样,所以啊,如果vue官方仓库能在gitee上维护一个仓库就太棒了。

这里,我提供一个自己在gitee上找的私人上传的vue3源码仓库,希望能帮助跟我一样进不去github或者在github上clone失败的同学。

现在,访问以上地址将源码clone 到本地就可以了

2. 安装依赖

2.1 使用VsCode打开源码

2.2 下载依赖

注意: 下载依赖时, 请使用 yarn 下载,使用 npm 不好使。

3. 调试源代码

3.1 启用source map

source map是啥?那个,自己百度一下子哈,我一下子也说不清楚,哈哈!

如果想要在源码中打断点进行调试,需要满足2个条件:

  • 开启source map模式;
  • 把源码跑起来;

如何启用source map?

  • 找到vue3源码的 package.json文件;
  • 在package.json源码打包脚本中,添加--sourcemap 的配置
json 复制代码
"scripts": {
    "dev": "node scripts/dev.js --sourcemap", // 这里添加 --sourcemap,开启sourcemap模式
    "build": "node scripts/build.js",
    "size": "node scripts/build.js vue runtime-dom size-check -p -f global",
    "lint": "eslint --ext .ts packages/*/src/**",
    "format": "prettier --write --parser typescript \"packages/**/*.ts?(x)\"",
    "test": "node scripts/build.js vue -f global -d && jest --runInBand",
    "test-dts": "node scripts/build.js shared reactivity runtime-core runtime-dom -dt -f esm-bundler && yarn test-dts-only",
    "test-dts-only": "tsc -p ./test-dts/tsconfig.json && tsc -p ./test-dts/tsconfig.build.json",
    "release": "node scripts/release.js",
    "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s",
    "dev-compiler": "npm-run-all --parallel \"dev template-explorer\" serve",
    "serve": "serve",
    "open": "open http://localhost:5000/packages/template-explorer/local.html",
    "preinstall": "node ./scripts/checkYarn.js",
    "prebuild-sfc-playground": "node scripts/build.js compiler shared -af cjs && node scripts/build.js runtime reactivity shared -af esm-bundler && node scripts/build.js vue -f esm-bundler-runtime && node scripts/build.js vue -f esm-browser-runtime && node scripts/build.js compiler-sfc -f esm-browser",
    "build-sfc-playground": "cd packages/sfc-playground && vite build"
  },

3.2 打包运行vue3源码

在终端中运行yarn dev 命令,进行打包:

bash 复制代码
yarn dev

打包后的文件,在下图所示目录: packages/vue/dist/vue-global.js

3.3 运行examples目录下的demo文件

如下图所示的文件,随便点一个,使用live-server 打开。

如果没有安装live-server,需要先装一下

运行起来后,可以看到示例中的demo已经可以正常访问了,如下图所示: 重点看下图中控制台中的地方,这里我们在Source 下,已经可以看到,packages目录下的源码了。 ,之后我们就可以在devTools中,对源码进行断点调试了。 如下图所示:

最后,这里我们对比一下,没用启动 source map 时,devTools的情况: 可以看到,如果没有启用 sourcemap,是无法调试源码的。

结语

好了,就记录到这里了,想要调试源码的同学,可以开整了。

相关推荐
小二·8 分钟前
Python Web 开发进阶实战:微前端架构初探 —— 基于 Webpack Module Federation 的 Vue 微应用体系
前端·python·架构
内存不泄露11 分钟前
人脸识别考勤系统
ide·vue.js·python
阿呆59112 分钟前
html前端开发注释的写法
前端·html
pusheng202515 分钟前
守护能源与数据的安全防线:从UL 2075标准解析储能及数据中心氢探技术的演进
前端·安全
.又是新的一天.20 分钟前
【前端Web开发HTML5+CSS3+移动web视频教程】02 html - 列表、表格、表单
前端·html·html5
程序员鱼皮20 分钟前
你的 IP 归属地,是咋被挖出来的?
前端·后端·计算机·程序员·互联网·编程经验
小酒星小杜22 分钟前
在AI时代,技术人应该每天都要花两小时来构建一个自身的构建系统 - 总结篇
前端·vue.js·人工智能
燕山石头25 分钟前
jeecg统一异常处理根据不同模块返回指定响应信息
前端
PyHaVolask38 分钟前
CSRF跨站请求伪造
android·前端·csrf
程序员海军1 小时前
我的2025:做项目、跑副业、见人、奔波、搬家、维权、再回上海
前端·程序员·年终总结