| 
                        副标题[/!--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; 
 
  
可以看到,我们捕获到了异常: 
  
                        (编辑:91站长网) 
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! 
                     |