| 副标题[/!--empirenews.page--]   前端一直是距离用户最近的一层,随着产品的日益完善,我们会更加注重用户体验,而前端异常却如鲠在喉,甚是烦人。 一、为什么要处理异常?异常是不可控的,会影响最终的呈现结果,但是我们有充分的理由去做这样的事情。 1.增强用户体验;2.远程定位问题;
 3.未雨绸缪,及早发现问题;
 4.无法复线问题,尤其是移动端,机型,系统都是问题;
 5.完善的前端方案,前端监控系统;
 对于 JS而言,我们面对的仅仅只是异常,异常的出现不会直接导致JS引擎崩溃,最多只会使当前执行的任务终止。 二、需要处理哪些异常?对于前端来说,我们可做的异常捕获还真不少。总结一下,大概如下: 
    JS语法错误、代码异常AJAX请求异常静态资源加载异常Promise异常Iframe异常跨域 Script error崩溃和卡顿 下面我会针对每种具体情况来说明如何处理这些异常。 三、Try-Catch 的误区try-catch只能捕获到同步的运行时错误,对语法和异步错误却无能为力,捕获不到。1.同步运行时错误:
 try { let name = 'jartto'; console.log(nam); } catch(e) { console.log('捕获到异常:',e); } 
 输出: 捕获到异常: ReferenceError: nam is not defined at <anonymous>:3:15 
 2.不能捕获到语法错误,我们修改一下代码,删掉一个单引号: try { let name = 'jartto; console.log(nam); } catch(e) {   console.log('捕获到异常:',e); } 
 输出: Uncaught SyntaxError: Invalid or unexpected token 
 不过语法错误在我们开发阶段就可以看到,应该不会顺利上到线上环境。 3.异步错误 try { setTimeout(() => { undefined.map(v => v); }, 1000) } catch(e) { console.log('捕获到异常:',e); } 
 我们看看日志: Uncaught TypeError: Cannot read property 'map' of undefined at setTimeout (<anonymous>:3:11) 
 并没有捕获到异常,这是需要我们特别注意的地方。 四、window.onerror 不是万能的当 JS运行时错误发生时,window会触发一个ErrorEvent接口的error事件,并执行window.onerror()。 /** * @param {String} message 错误信息 * @param {String} source 出错文件 * @param {Number} lineno 行号 * @param {Number} colno 列号 * @param {Object} error Error对象(对象) */   window.onerror = function(message, source, lineno, colno, error) { console.log('捕获到异常:',{message, source, lineno, colno, error}); } 
 1.首先试试同步运行时错误 window.onerror = function(message, source, lineno, colno, error) { // message:错误信息(字符串)。 // source:发生错误的脚本URL(字符串) // lineno:发生错误的行号(数字) // colno:发生错误的列号(数字) // error:Error对象(对象) console.log('捕获到异常:',{message, source, lineno, colno, error}); } Jartto; 
 可以看到,我们捕获到了异常: 
 (编辑:宣城站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |