vscode 调试 Node.js 入门
VSCode 不仅是一个文本编辑器,还可以作为一些脚本的调试环境来使用,尤其是对 Node.js 开发调式支持的非常完善。
调试 Node.js 程序
-
首先新建后缀为 js 文件,录入以下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13const http = require('http');
const hostname = '127.0.0.1';
const port = 3000;
const server = http.createServer((req,res) => {
res.statusCode = 200;
res.setHeader('Content-Type', 'text/plain');
res.end('Hello World\n');
});
server.listen(port, hostname, () =>{
console.log(`Server running at http://${hostname}:${port}/`);
}) -
在侧边栏上点击 Debug 选项
-
打开 launch.json 添加 “runtimeExecutable” 指向node.exe 路径
-
打断点,开始调试
-
在浏览器中输入 “http://127.0.0.1:3000/” 显示
同时,vscode 调试控制台显示输出
VSCode launch.json 配置详解
lauch.json 启动配置文件设置了调试程序中用到的相应参数,分为launch(启动) 和 attach(附加)两种:
1 | { |
类型 launch 和 attach 类型共有的属性:
- protocol 设置调试协议
- auto 尝试自动检测目标运行时使用的协议
- inspector 新的V8调试器协议,解决遗留版本的多数问题,node versions >= 6.3 and Electron versions >= 1.7.4.
- legacy 原始的v8调试器协议,node versions < v8.0 and Electron versions < 1.7.4.
- port调试使用的端口
- address TCP/IP地址,用于远程调试
- localRoot 远程调试时映射的本地地址
- remoteRoot 远程调试时的远程目录地址
- sourceMaps 默认为true
- outFiles 当map文件不在js文件同目录时用于指定 sourceMaps的位置
- restart 自动重启调试
- timeout 配置自动附加的超时时间
- stopOnEntry 自动断点到第一行代码处
- smartStep 自动跳过未映射到源代码的代码
- skipFiles :[]String,指定跳过单步调试的代码
1
2
3
4
5"skipFiles": [
"${workspaceFolder}/node_modules/**/*.js", //跳过node_modules
"${workspaceFolder}/lib/**/*.js",//跳过lib
"<node_internals>/**/*.js"//跳过node核心模块
] - trace启用诊断输出
类型 launch(启动) 特定的配置属性
- program 指定调试入口文件地址
- args :[]String 传递给程序的参数,可在process.argv拿到
- cwd 指定程序启动调试的目录 ,当vscode启动目录不是项目根目录,并且调试npm script时非常有用
- runtimeExecutable 设置运行时可执行文件路径,默认是node可以是其他的执行程序,如npm、nodemon
- runtimeArgs 传递给运行时可执行文件的参数,例如:
1
2
3
4
5
6
7
8
9
10
11
12
13{
"type": "node",
"request": "launch",
"name": "npm launch app",
"args":["a"],
"runtimeExecutable": "npm",
"runtimeArgs": [
"run-script",
"app",
"b"
],
"port": 6666
} - 打印参数可以发现 args 、runtimeArgs都会传给程序,但是runtimeArgs参数会紧跟可执行文件
- runtimeVersion 设置运行时可执行程序的版本,如果使用nvm,可以切换node.js版本
- env 添加额外的环境变量
- envFile 文件加载环境变量
- console 配置终端可以是外部终端或者内部集成终端,默认值internalConsole
- outputCapture -如果设置为std,则进程stdout / stderr的输出将显示在调试控制台中,而不是侦听调试端口上的输出。这对于直接写入stdout / stderr流而不是使用console.*API的程序或日志库很有用。
- autoAttachChildProcesses 跟踪调试对象的所有子过程,并自动附加到在调试模式下启动的子过程
类型 attach(附加) 特定的配置属性
- processId 指定nodejs进程id,由于每次启动都会变,传入"${command:PickProcess}"
问与答
-
如果使用了符号链接怎么调试?
传递参数:1
2
3{
"runtimeArgs": ["--preserve-symlinks"]
}如果主脚本也在符号链接路径里面,需要再传递一个参数"–preserve-symlinks-main",支持的版本是 Node 10+.
-
如何调试ECMAScript模块?
如果使用esm或传递–experimental-modules给Node.js以便使用ECMAScript模块,则可以传递这些选项通过runtimeArgs属性:- “runtimeArgs” : [“–experimental-modules”] -使用Node v8.5.0 +中的实验性ECMAScript模块支持
- “runtimeArgs” : [“-r”, “esm”] -使用 esm ES 模块加载器(请注意,[“-r esm”]如果没有逗号,则无法使用)
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 水 流 记!