如何在 JavaScript 中记录没有堆栈跟踪的错误消息?

Nic*_*ert 5 javascript error-handling stack-trace node.js traceback

我想在不退出程序的情况下记录发生的错误,因此我将可能会引发错误的代码包含在try-catch这样的块中

try
{
    let query = parseStatement(input); // might throw an error
    console.log(query);
}
catch (err)
{
    console.error(err); // logs the entire error with stack trace
}
finally
{
    this.prompt();
}
Run Code Online (Sandbox Code Playgroud)

我想获得的输出是没有整个堆栈跟踪的错误消息。大致如下:

Error: Missing semicolon at the end of statement: <statement>

并不是

Error: Missing semicolon at the end of statement: <statement>
    at error (/home/nic/dev/nodedb/src/errors.js:5:11)
    at Function.tokenize (/home/nic/dev/nodedb/src/tokens.js:53:13)
    at parseStatement (/home/nic/dev/nodedb/src/sql.js:35:24)
    at Shell.onData (/home/nic/dev/nodedb/src/shell.js:49:25)
    at ReadStream.emit (node:events:394:28)
    at addChunk (node:internal/streams/readable:312:12)
    at readableAddChunk (node:internal/streams/readable:287:9)
    at ReadStream.Readable.push (node:internal/streams/readable:226:10)
    at TTY.onStreamRead (node:internal/stream_base_commons:190:23)
Run Code Online (Sandbox Code Playgroud)

Nic*_*ert 3

文档中:

Error对象有一个.message属性,因此不必打印整个错误,只需

console.error(error.message);
Run Code Online (Sandbox Code Playgroud)

  • 即使是纯文本也会有堆栈跟踪。不是为了自己。但是对于您编写“console.error()”的位置。 (5认同)
  • @LawrenceCherone 上没有这样的问题/答案,所以我认为其他人可能会偶然发现需要在没有整个堆栈跟踪的情况下记录错误。我认为这个问题/答案可能会节省其他人阅读文档的时间 (3认同)
  • 对于我在 Nodejs 中这不起作用。即使只有 error.message,它也会记录调用堆栈。 (2认同)