javascript node.js在try catch中获取行号?

时间:2011-04-27 10:49:08

标签: javascript node.js try-catch

我在node.js脚本上使用try catch:

try {} catch (err) {console.log(err)}

我得到这样的输出:

{ stack: [Getter/Setter],
  arguments: [ 'undefined' ],
  type: 'called_non_callable',
  message: [Getter/Setter] }

是否有一种简单的方法可以提供更多信息?包括行号和函数名称等?

1 个答案:

答案 0 :(得分:52)

那些[Getter/Setter]成员指出有关错误对象的更多信息。您可以使用小辅助函数轻松转储这些getter / setter的内容(非常简单的实现,进一步细化取决于您)

function dumpError(err) {
  if (typeof err === 'object') {
    if (err.message) {
      console.log('\nMessage: ' + err.message)
    }
    if (err.stack) {
      console.log('\nStacktrace:')
      console.log('====================')
      console.log(err.stack);
    }
  } else {
    console.log('dumpError :: argument is not an object');
  }
}

try {
  not_defined.function_call();
} catch(err) {
  dumpError(err);
}

您还可以扩展Object.prototype以提高可访问性(因此您可以使用err.dumpError()),但扩展Object.prototype可能会覆盖现有功能。