起因
要捕获 JavaScript 代码中的异常一般会采用 try catch,不过 try catch 的使用是否是对代码性能产生影响呢?答案是肯定有的,但是有多少不得而知。
前端线上脚本错误的捕获方法:
window . JSTracker = window . JSTracker || [ ] ;
try {
//your code
} catch ( e ) {
JSTracker . push ( e ) ;
throw e ; //建议将错误再次抛出,避免测试无法发现异常
}
设计实验方式
简单的设计方案也就是对比实验。
空白组1:[无 try catch 的情况下对数据取模1千万次耗时]
1无 try catch的情况耗时
<script></script>
! function ( ) {
//无try catch的情况耗时
var t = new Date ( ) ;
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
document . write ( new Date ( ) – t ) ;
} ( ) ;
参照组2:[将耗时代码用 try 包围,内联耗时代码]
2在 try中内联代码的耗时情况
<script></script>
! function ( ) {
//在 try 中内联代码的耗时情况
var t = new Date ( ) ;
try {
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
throw new Error ( ) ;
} catch ( e ) {
}
document . write ( new Date ( ) – t ) ;
} ( ) ;
参照组3:[将耗时代码用 try 包围,外联耗时代码]
3在 try中内联代码的耗时情况
<script></script>
! function ( ) {
function run ( ) {
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
}
//在 try 中内联代码的耗时情况
var t = new Date ( ) ;
try {
run ( ) ;
throw new Error ( ) ;
} catch ( e ) {
}
document . write ( new Date ( ) – t ) ;
} ( ) ;
参照组4:[将耗时代码用 catch 包围,内联耗时代码]
4在 catch中内联代码的耗时情况
<script></script>
! function ( ) {
//在 catch 中内联代码的耗时情况
var t = new Date ( ) ;
try {
throw new Error ( ) ;
} catch ( e ) {
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
}
document . write ( new Date ( ) – t ) ;
} ( ) ;
参照组5:[将耗时代码用 catch 包围,外联耗时代码]
5在 catch中内联代码的耗时情况
<script></script>
! function ( ) {
function run ( ) {
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
}
//在 catch 中内联代码的耗时情况
var t = new Date ( ) ;
try {
throw new Error ( ) ;
} catch ( e ) {
run ( ) ;
}
document . write ( new Date ( ) – t ) ;
} ( ) ;
运行结果(只选取了 Chrome 作为示例)
– | 不使用 try-catch | try 中耗时,内联代码 | try 中耗时,外联代码 | catch 中耗时,内联代码 | catch 中耗时,外联代码 |
---|---|---|---|---|---|
Chrome51 | 98.2 | 1026.9 | 107.7 | 1028.5 | 105.9 |
给出总结
-
使用 try catch 的使用无论是在 try 中的代码还是在 catch 中的代码性能消耗都是一样的。
-
需要注意的性能消耗在于 try catch 中不要直接塞进去太多的代码(声明太多的变量),最好是吧所有要执行的代码放在另一个 function 中,通过调用这个 function 来执行。
针对第二点,可以查看 ECMA 中关于 try catch 的解释,在代码进入 try catch 的时候 js引擎会拷贝当前的词法环境,拷贝的其实就是当前 scope 下的所有的变量。
建议
在使用 try catch 的时候尽量把 try catch 放在一个相对干净的 scope 中,同时在 try catch 语句中也尽量保证足够少的变量,最好通过函数调用方式来 try catch。
试验中的现象解释
测试过程中还是发现了一个疑问, 以下两段代码在 Chrome 44 中运行出来的结果差距非常大,加了一句空的 try catch 之后平均为:850ms,加上之前为:140ms。
! function ( ) {
//无 try catch 的情况耗时
var t = new Date ( ) ;
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
document . write ( new Date ( ) – t ) ;
try {
} catch ( e ) {
}
} ( ) ;
! function ( ) {
//无 try catch 的情况耗时
var t = new Date ( ) ;
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
document . write ( new Date ( ) – t ) ;
} ( ) ;
其实原因很简单
只要把代码改为这样 耗时就降下来了:
! function ( ) {
! function ( ) {
//无 try catch 的情况耗时
var t = new Date ( ) ;
//耗时代码开始
for ( var i = 0 ; i
var p = i % 2 ;
}
//耗时代码结束
document . write ( new Date ( ) – t ) ;
} ( ) ;
try {
} catch ( e ) {
}
} ( ) ;

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

HTML、CSS和JavaScript在网页开发中的角色分别是:HTML负责内容结构,CSS负责样式,JavaScript负责动态行为。1.HTML通过标签定义网页结构和内容,确保语义化。2.CSS通过选择器和属性控制网页样式,使其美观易读。3.JavaScript通过脚本控制网页行为,实现动态和交互功能。

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增强WebevebDevelopment。

HTML是构建网页结构的基石。1.HTML定义内容结构和语义,使用、、等标签。2.提供语义化标记,如、、等,提升SEO效果。3.通过标签实现用户交互,需注意表单验证。4.使用、等高级元素结合JavaScript实现动态效果。5.常见错误包括标签未闭合和属性值未加引号,需使用验证工具。6.优化策略包括减少HTTP请求、压缩HTML、使用语义化标签等。

HTML是一种用于构建网页的语言,通过标签和属性定义网页结构和内容。1)HTML通过标签组织文档结构,如、。2)浏览器解析HTML构建DOM并渲染网页。3)HTML5的新特性如、、增强了多媒体功能。4)常见错误包括标签未闭合和属性值未加引号。5)优化建议包括使用语义化标签和减少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

Atom编辑器mac版下载
最流行的的开源编辑器

禅工作室 13.0.1
功能强大的PHP集成开发环境