内容简介:”JS 代码压缩后,定位具体出错代码困难!“的问题,我们可以通过 SourceMap 快速定位,处理得到源文件的具体错误信息。具体方式可以查看然而当项目外链第三方资源或公共库时,这种压缩且无提供 SourceMap 的文件出现异常,又该如何更好的定位错误位置呢?我们可以将压缩代码进行格式化,当错误出现时,错误信息也就有了具体的行列数,更够方便定位到错误位置。
”JS 代码压缩后,定位具体出错代码困难!“的问题,我们可以通过 SourceMap 快速定位,处理得到源文件的具体错误信息。具体方式可以查看 《脚本错误量极致优化-让脚本错误一目了然》
然而当项目外链第三方资源或公共库时,这种压缩且无提供 SourceMap 的文件出现异常,又该如何更好的定位错误位置呢?
” 获取对应格式化后的代码行列位置 “
我们可以将压缩代码进行格式化,当错误出现时,错误信息也就有了具体的行列数,更够方便定位到错误位置。
!function(n) { // ... // ... }([ function(n, r) { function t() { noerror; } t(); } ]);
而此时,格式化后的代码由于增加了换行和空格,增加了文件的大小,所以并不推荐这种方式。 但这种试图 “通过压缩代码的出错行列位置转换成格式化代码对应的出错行列位置” 的思路我们可以接着进行优化。将格式化代码的转换进行后置处理。借助工具,避免提前格式化导致的文件增大问题。
“通过压缩代码及行列位置获取对应格式化后的代码行列位置” 的工具
我们可以将压缩代码进行格式化,并结合原来的压缩代码匹配生成 “映射文件” - SourceMap 文件。
有了 SourceMap 文件后,就能够通过压缩代码的行列数找到对应格式化后代码的行列数了。
小结
当遇到压缩且无源码 SourceMap 的文件出错时,借助上面提到的 “工具”,能够找到其对应格式化后的代码及出错位置,更好的定位具体问题。具体 工具 的使用与实现方式可见 https://github.com/joeyguo/js-beautify-sourcemap
以上所述就是小编给大家介绍的《脚本错误量极致优化-定位压缩且无 SourceMap 文件的脚本错误》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 开源前端脚本错误监控及跟踪解决项目BadJS试用
- syntax error near unexpected token 脚本报错误解决
- 脚本文件里的 Hybrid Script(混合式脚本)
- Golang学习笔记之错误处理error、panic (抛出错误),recover(捕获错误)
- 如何从PHP脚本(如批处理文件)中运行多个PHP脚本?
- 荐 python脚本如何监听终止进程行为,如何通过脚本名获取pid
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。