- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
前端代码异常日志收集与监控在复杂的网络环境和浏览器环境下,自测、QA测试以及 Code Review 都是不够的,如果对页面稳定性和准确性要求较高,就必须有一套完善的代码异常监控体系,本文从前端代码异常监控的方法和问题着手,尽量全面地阐述错误日志 收集各个阶段中可能遇到的阻碍和处理方案。收集日志的方法平时收集日志的手段,可以归类为两个方面,一个是逻辑中的错误判断,为主动判断;一个是利用语言给我们提供的捷径,暴力式获取错误信息,如 try..catch 和 window.onerror。1. 主动判断我们在一些运算之后,得到一个期望的结果,然而结果不是我们想要的//?test.js?function?calc(){??//?code...??return?val;}if(calc()?!==?someVal){?Reporter.send({?position:?test.js::Functioncalc?msg:?calc?error?});}?这种属于逻辑错误/状态错误的反馈,在接口 status 判断中用的比较多。2. try..catch 捕获判断一个代码段中存在的错误:try?{??init();??//?code...?}?catch(e){??Reporter.send(format(e));}?以 init 为程序的入口,代码中所有同步执行出现的错误都会被捕获,这种方式也可以很好的避免程序刚跑起来就挂。3. window.onerror捕获全局错误:window.onerror?=?function()?{??var?errInfo?=?format(arguments);??Reporter.send(errInfo);??return?true;};?在上面的函数中返回 return true,错误便不会暴露到控制台中。下面是它的参数信息:/**?*?@param?{String}??errorMessage?错误信息?*?@param?{String}??scriptURI?出错的文件?*?@param?{Long}lineNumber?出错代码的行号?*?@param?{Long}columnNumber?出错代码的列号?*?@param?{Object}??errorObj?错误的详细信息,Anything?*/window.onerror?=?function(errorMessage,?scriptURI,?lineNumber,columnNumber,errorObj)?{//?code..?}?window.onerror 算是一种特别暴力的容错手段,try..catch 也是如此,他们底层的实现就是利用 C/C++ 中的 goto 语句实现,一旦发现错误,不管目前的堆栈有多深,不管代码运行到了何处,直接跑到顶层或者 try..catch 捕获的那一层,这种一脚踢开错误的处理方式并不是很好。收集日志存在的问题收集日志的目的是为了及时发现问题,最好日志能够告诉我们,错误在哪里,更优秀的做法是,不仅告诉错误在哪里,还告诉我们,如何处理这个错误。终极目标是,发现错误,自动容错,这一步是最难的。1. 无具体报错信息,Script error.先看下面的例子,test.html!--?http://barret/test.html?--?script?window.onerror?=?function(){????console.log(arguments);??};/script?script?src=http://barret/test.js/script??test.js??//?http://barret/test.js?function?test(){??ver?a?=?1;??return?a+1;}test();?我们期望收集到的日志是下面这样具体的信息:为了对资源进行更好的配置和管理,我们通常将静态资源放到异域上!--?http://barret/test.html?--?script?window.onerror?=?function(){????console.log(arguments);??};/script?script?src=http://localhost/test.js/script?而拿到的结果却是:翻开 Chromium 的 WebCore /browser/branches/chromium/1453/Source/WebCore/dom/ScriptExecutionContext.cpp源码,可以看到:跨域情况下,返回的结果是 Script error.。// /browser/branches/chromium/1453/Source/WebCore/dom
您可能关注的文档
最近下载
- 江苏省梅村高级中学2022年物理高一年级上册期末经典试题含解析.pdf VIP
- GB∕T 50298-2018 风景名胜区总体规划标准.docx VIP
- 2024-2025学年江苏省无锡市滨湖区梅村高级中学空港分校高一(上)期中物理试卷(含答案).docx VIP
- 2024—2025学年江苏省梅村高级中学高一上学期期中检测化学试卷.doc VIP
- 2023-2024学年江苏省无锡市梅村高级中学高一(上)期中数学试卷【答案版】.docx VIP
- 上海三菱电梯LEHY-IIC维修资料LEHYⅡC慢车⒈对线路进行.DOC VIP
- 2024-2025江苏无锡梅村高级中学高一(上)期中数学试卷【答案版】.pdf VIP
- 上消化道出血应急预案流程图[实用].docx VIP
- 2021年7月10日四川广元昭化区部分事业单位考试《综合知识》精选题.pdf VIP
- 三菱电梯LEHY(C) LEHY-III LEHY-MRL电梯安装调试培训资料(2).pptx VIP
有哪些信誉好的足球投注网站
文档评论(0)