编译并运行 Chrome Devtools Frontend
Chrome DevTools 工作原理简单介绍
Devtools 不只是我们在浏览器中按F12所打开的调试界面,它是 Chromium 的一部分,在 Electron 中也有集成。
Devtools 主要由四部分组成:
- Frontend: 调试器前端,默认由 Chromium 内核层集成,DevTools Frontend 是一个 Web 应用程序,就是 JS + CSS + HTML 组成的;
- Backend: 调试器后端,广义上主要由 Chromium、V8 或 Node.js(v8)提供,用来与 Frontend 连接与通信;
- Protocol: 通信协议,调试器前端和后端通过此协议通信,协议遵循 JSON RPC2.0 规范;
- Connection: 连接层,目前有
WebSocketConnection
、StubConnection
、MainConnection
三种连接方式,查看其他资料,也有说是消息通道,即 Embedder Channel、WebSocket Channel、Chrome Extensions Channel、USB/ADB Channel,但是我在当前的版本没有找到这部分代码;
Devtools Frontend 编译
clone devtools-frontend 源码
1
$ git clone git@github.com:ChromeDevTools/devtools-frontend.git
安装 depot_tools
1
2
3
4
5
6
7
8
9
10# 必须安装此工具才能编译 devtools-frontend
# 下载 depot_tools 源码
$ git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
# 将其添加到本机环境变量中
$ export PATH=$PATH:/path/to/depot_tools
# 使环境变量修改立即生效
$ source ~/.bash_profile只检出 DevTools frontend 的代码,因为 DevTools Frontend 可独立于 Chromium 作为独立项目构建,并且如果不执行这一步,编译会报错:
gn.py: Could not find checkout in any parent of the current path. This must be run inside a checkout.
1
2
3
4$ mkdir devtools
$ cd devtools
$ fetch devtools-frontend
# 注意,上一步可能会由于网络问题导致 git 相关操作失败,可通过配置 git 和终端代理解决构建
1
2
3
4$ cd devtools-frontend
$ gn gen out/Default
$ autoninja -C out/Default
# 构建产物在 devtools-frontend/devtools/devtools-frontend/out/Default 文件夹中
运行 devtools frontend 产物
1 | # 进入到构建产物目录 |
查看构建产物目录,这几个 html 其实就是调试前端面板:
比如打开 http://127.0.0.1:8080/devtools_app.html
,就是我们熟悉的 web 页面调试界面:
也可以自己尝试打开其他html,如 http://127.0.0.1:8080/node_app.html
,http://127.0.0.1:8080/inspector.html
等
结合 node inspect 来调试 nodejs 代码
如上一篇所讲,先准备带调试的 nodejs 实例:
1 | $ node --inspect=9222 for-inspect.js |
然后访问 http://localhost:9222/json
获取到 devtoolsFrontendUrl
,类似于 devtools://devtools/bundled/js_app.html?experiments=true&v8only=true&ws=localhost:9222/8c4626a1-2903-4da8-9759-5de3c74c3a35
只需要将其 query
参数拼接到 http://127.0.0.1:8080/***.html
后面即可,拼接后类似于 http://127.0.0.1:8080/inspector.html?experiments=true&v8only=true&ws=localhost:9222/8c4626a1-2903-4da8-9759-5de3c74c3a35
,在浏览器中打开后的效果如图:
从 devtools 中查看 Chrome Devtools Protocol 🧐
在 Settings -> Experiments
中打开 Protocol Monitor
选项:
显示 Protocol Monitor
:
定制调试面板的显示,只需要 console、source、network 面板
很多情况下,我们想自定义调试界面需要显示哪些面板。比如我只需要 console、source、network 这三个面板,不需要其他的,而且全部集成也不太现实,因为加载速度太慢。
观察其产物的js,这里以 inspector.html
解释:
说明其入口 js 为 ./entrypoints/inspector/inspector.ts
,查看其原始代码:
这里能看出来,inspector_app
相比 devtools_app
增加了 screencast
面板的功能。
所以我们大致得出结论,如果想要定制调试面板的现实,只需要修改对应 entrypoints/***_app
下的代码即可。
改造 devtools_app
通过查看 devtools_app 的界面,因为我们只需要 console、source、network 三个面板,所以需要移除多余的调试面板: