对于较小的Node.js代码,您可以使用 console.log() 或 console.debug() 函数间歇性地显示消息或变量的值,以手动调试代码。但是,如果Node.js代码变得更大、更复杂,则手动方法没有帮助。相反,我们可以在运行时中使用内置Node.js调试器。
考虑一个简单的Node.js代码,如下所示 (main.js) -
我们预计上述程序会计算 5 名学生获得的平均分数。但是,结果不是我们预期的,当我们按如下方式运行它时 -
在 JavaScript 中,NaN 表示不是数字。为了跟踪此错误,让我们使用 Node.js 调试器。相反,请使用以下命令运行程序 -
内置调试器从 localhost 的端口 9229 开始。调试器在代码的第一行中断。
我们通过告诉调试器转到程序将执行的下一行来逐步执行代码。Node.js允许以下命令使用调试器 -
命令 | 描述 |
---|---|
c or cont |
继续执行到下一个断点或程序结束。 |
n or next |
移动到下一行代码。 |
s or step |
单步执行函数。默认情况下,我们只在正在调试的块或范围内单步执行代码。 |
o |
退出函数。单步执行函数后,当函数返回时,调试器将返回到主文件。 |
pause |
暂停正在运行的代码。 |
依次按 'n' 或 'next' 遍历代码。在此循环中,每次迭代都会更改两个变量 — total 和 i。让我们为这两个变量设置观察器。
当您在调试提示符前按“n”时,您可以看到监视下两个变量的瞬时值。
每次按 next 时,调试器中都会显示更改的值或总计和 I。
在最后一次迭代中,调试器的状态为 -
下次,total 的值变为 NaN,因为循环试图超出数组。
因此,我们可以知道错误在于 for 循环的形成。内置调试器有助于识别错误。
您还可以在 VS Code 中启用调试Node.js代码。按 ctrl+shift+p 打开命令面板,然后选择 Attach Node.JS 进程。然后从“运行”菜单开始调试程序。它允许您在代码中执行“单步跳过”、“单步执行”和“单步执行”操作,以跟踪程序的流程。您还可以在一个或多个变量上设置监视,以便在逐步执行程序时跟踪值。