激情燃烧的木炭

微笑生活,努力工作,让我们做得更好!

Javascript 中全局错误捕捉

📚 学习

error.error && ! if (! if (f === f.window. } ext = ext. msg = ext; } //没有URL不上报! m += FF. m += FF. m += FF.onerror = function(msg, url, line, col, error) { if (!= "Script error.上报也不知道错误 // if (msg ! var f = arguments.event && window.

// 捕捉全局错误
var isDebug = false;
window.onerror = function(msg, url, line, col, error) {
if (!isDebug) {
return false;
}

//没有URL不上报!上报也不知道错误
//  if (msg != "Script error." && !url) {
//  return true;
//  }
//采用异步的方式
//我遇到过在window.onunload进行ajax的堵塞上报
//由于客户端强制关闭webview导致这次堵塞上报有Network Error
//我猜测这里window.onerror的执行流在关闭前是必然执行的
//而离开文章之后的上报对于业务来说是可丢失的
//所以我把这里的执行流放到异步事件去执行
//脚本的异常数降低了10倍

setTimeout(function() {
var m = '';

//不一定所有浏览器都支持col参数
col = col || (window.event && window.event.errorCharacter) || 0;


if (!!error && !!error.stack) {
//如果浏览器有堆栈信息
//直接使用
msg = error.stack.toString();
} else if (!!arguments.callee) {
//尝试通过callee拿堆栈信息
var ext = [];
var f = arguments.callee.caller,
c = 3;
//这里只拿三层堆栈信息
while (f && (--c > 0)) {
ext.push(f.toString());
if (f === f.caller) {
break; //如果有环
}
f = f.caller;
}
ext = ext.join(",");
msg = ext;
}

/*
以下部分为自实现代码,如需使用请修改为自己的输出内容

var f = '<li><b>{0}</b>:<i>{1}</i></li>'
m += FF.strFormat(f, '来源', url);
m += FF.strFormat(f, '行号', line);
m += FF.strFormat(f, '位置', col);
m += FF.strFormat(f, '消息', msg)

FS.modal.show({
title: '系统脚本错误',
content: m
})
}, 0);
*/

return false; //返回true是因为不需要在console中打印错误了
};

来源: 编辑: 关键词:error if window
  • Javascript 动态加载脚本(JS)资源(.css .less)文件等