本地调试
在 VSCode 中调试
方法一:使用 JavaScript Debug Teminal
在 VSCode 的终端下拉出,隐藏着一个 JavaScript Debug Terminal
,点击它,创建出来的终端将自带调试能力。
data:image/s3,"s3://crabby-images/93822/9382201f73c2f001480dc1cbe504e74b7c7ffd4c" alt=""
输入任意的命令都将自动开启 Debug,比如输入 npm run dev
后。
data:image/s3,"s3://crabby-images/d2fa1/d2fa17b4186d01e26201c7a225afecda223113be" alt=""
方法二:配置调试文件
创建一个 vscode 的启动文件。
data:image/s3,"s3://crabby-images/99402/99402dc31507248af44dd7745c92b2e1167f07c6" alt=""
随便选一个,会创建 .vscode/launch.json
文件,
data:image/s3,"s3://crabby-images/47c43/47c431aafa234276c9fd1ae753dfb28ee0cb427a" alt=""
将下面内容复制进去。
{
// 使用 IntelliSense 了解相关属性。
// 悬停以查看现有属性的描述。
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "Midway Local",
"type": "node",
"request": "launch",
"cwd": "${workspaceRoot}",
"runtimeExecutable": "npm",
"windows": {
"runtimeExecutable": "npm.cmd"
},
"runtimeArgs": ["run", "dev"],
"env": {
"NODE_ENV": "local"
},
"console": "integratedTerminal",
"protocol": "auto",
"restart": true,
"port": 7001,
"autoAttachChildProcesses": true
}
]
}
启动断点即可。
data:image/s3,"s3://crabby-images/d4583/d458369287581bda95d16d7b2f8a36e9eef3eabf" alt=""
在 WebStorm/Idea 中调试
开始配置 IDE。
data:image/s3,"s3://crabby-images/403b0/403b0d5b264dc57c7d53014463d4508a7b29b0a3" alt=""
配置 npm 命令。
data:image/s3,"s3://crabby-images/4b6bf/4b6bf8cd0bcdbbaa269b3b394203484afc9f7008" alt=""
选择你的 package.json
后,下拉选择 Scrips
,其中是你 package.json
中配置好的 scripts
中的命令,选择你要的命令,比如 dev
或者 test
等即可 。
data:image/s3,"s3://crabby-images/ac5ea/ac5ea028a8ec67cf6fcbf30d765741fce0ce1943" alt=""
在代码上断点后执行调试即可。
data:image/s3,"s3://crabby-images/0c401/0c401393f440299c74c3d607f1a65201f4013c5c" alt=""
在 Chrome 中调试
如果您使用 vim 或其他代码编辑器,可以使用此方式,通过 @midwayjs/cli
的 dev
命令,添加 --debug
参数启动 debug 模式,可以通过 chrome devtools
进行单步代码调试:
data:image/s3,"s3://crabby-images/a4ec2/a4ec2a7bcbb9c110d4da8b2ad813f1b31289c643" alt=""
您可以通过 chrome://inspect/
打开 nodejs devtools
进行断点调试:
data:image/s3,"s3://crabby-images/32df5/32df5f4a7b8614d146a88d071541d24f14db97d0" alt=""
data:image/s3,"s3://crabby-images/bc750/bc7500f7d38be00556c50f80572e3b02b9e96be5" alt=""
您也可以直接通过 chrome 浏览器打开命令行中输出的 devtools
协议的链接,给对应代码添加断点后调试:
data:image/s3,"s3://crabby-images/afe83/afe83e9132d19373ad4617696f56904fdbc47fe7" alt=""