我正在尝试将我所有的Javascript异常,无论是已处理的还是未处理的,都发送到服务器进行日志记录。我通过window.onerror documentation和also this post了解了这个问题,但它们只对未处理的异常有效。
如果异常已在catch()块中处理,则不会触发window.onerror。
一种“痛苦”的方法是将我的logToServer()函数手动附加到代码中的每个catch()块(它也可以工作),但我希望有一个更好的解决方案。
我在下面设置了一个小代码片段。
var logToServer = function logToServer() {
console.info('logToServer() called');
};
window.onerror = function(z, x, c, v, b) {
console.info(z);
console.info(x);
console.info(c);
console.info(v);
console.info(b);
// call a function to send to server
logToServer();
};
window.addEventListener('error', function(z, x, c, v, b) {
console.info(z);
// call a function to send to server
logToServer();
});
// test w/o catch-block
//console.info(err); // calls logToServer()
// test w/ catch-block
try {
console.info(asd); // does not call logToServer()
} catch (err) {
console.error(err);
};Enable logs in console.
发布于 2017-03-07 22:51:49
仅当异常未处理时,才会触发window.onerror。如果您捕获到任何异常,此事件将不会触发。您必须在所有try--catch块中显式地执行此操作。在catch块中,你必须抛出异常。语法很简单:
try{
//Your try logic
}
catch(ex){
// Your catch logic comes here
throw ex; //This will throw exception and window.onerror will be fired.
}https://stackoverflow.com/questions/42646313
复制相似问题