我在node.js脚本上使用try catch:
try {} catch (err) {console.log(err)}
我得到这样的输出:
{ stack: [Getter/Setter],
arguments: [ 'undefined' ],
type: 'called_non_callable',
message: [Getter/Setter] }
是否有一种简单的方法可以提供更多信息?包括行号和函数名称等?
答案 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
可能会覆盖现有功能。