有人知道如何在Node.js中打印堆栈跟踪吗?


当前回答

在v15.12.0中,有各种方法可以做到这一点,

1. console.trace(anything)
2. Error.captureStackTrace(Object)
3. console.log(new Error().stack)
4. Try Catch - Use console.log(e), where `e` is catched by catch block

或者更好地使用 在任何Javascript代码中的stacktracejs

其他回答

尝试错误。captureStackTrace (constructorOpt targetObject[])。

const myObj = {};
function c() {
  // pass
}

function b() {
    Error.captureStackTrace(myObj)
    c()
} 

function a() {
    b()
}

a()

console.log(myObj.stack)

函数a和b在错误堆栈中被捕获并存储在myObj中。

任何Error对象都有一个堆栈成员,该成员捕获了构造它的点。

var stack = new Error().stack
console.log( stack )

或者更简单地说:

console.trace("Here I am!")

您可以使用node-stack-trace模块,这是一个强大的完整模块来跟踪调用堆栈。

现在主机上有一个专门的功能:

console.trace()

据我所知,在nodejs中打印完整的堆栈跟踪是不可能的,你可以只打印“部分”堆栈跟踪,你无法看到你从代码中的哪里来,只是异常发生的地方。这就是瑞恩·达尔在youtube视频中解释的内容。http://youtu.be/jo_B4LTHi3I为了精确,至少56:30。希望这能有所帮助