做了这么久的前端工程师,总被朋友问到怎么写出高性能的javascript,那么我今天就来简单总结下,其实js本身是没有什么性能问题的,所谓 的内存泄露,也主要针对于IE6,IE7,而IE7的内存泄露问题也并不严重,这里不讨论浏览器造成的内存泄露问题,我们只讨论,养成什么样的书写习惯能 够写出,高效率高性能的js。
在这里我总结了三个书写js的习惯,然后分别针对执行效率,内存问题,安全等各个方面综合分析要养成这三个习惯的原因。
1.尽量使用局部变量:
局部变量的创建和访问都是特别廉价快捷的,而使用全局变量的话,js对全局变量的调用实际上是对 GLOBAL对象的查找引用,性能低下。 而局部变量则是直接创建于当前作用域,不需要有查找引用的过程。不单单是当前作用域,包括闭包里的局部变量访 问,都是很快的。不过,这个过程带来的优化是需要庞大的js程序长时间的运行才能体现出的。
下面通过细化js解析过程来理解下:
一个变量具体是局部变量还是全局变量,局部变量的话是在哪层闭包里,是第几个变量,在编译的时候就已经确定了,重复的var声明并不会影响js的执行效率,js执行时,如果是局部变量则会直接在向内存地址里取用,而全局变量则是对象访问,显然局部变量在效率上要优化的多。
但是,不是任何时候局部变量都是最优化的。
例如,当一个变量是一个表达式或者一个查找dom节点的过程等时,变量的取用中就带有了查找和计算过程,这样如果计算次数比较多,用全局变量则可以一次性的固化结果,而使用局部变量反而需要多次计算查找,而影响了效率了。
总结:
当然,以上的数据仅仅只对js代码的执行效率而言,在具体应用中,我仍然推荐大家尽量使用局部变量。因为,js的一个重要的编程理念就是不要污 染全局对象,全局对象可能被不同的模块(甚至页面上的广告)访问,在上面存放数据、函数会有不可预期的后果。所以,我们要灵活使用全局对象和局部变量。
2.及时释放回调函数,解除事件绑定。
上面一个习惯,主要针对于执行效率问题,而这个习惯则是针对内存泄露的问题了。除了古老浏览器本身的bug造成的内存泄露外,错误的书写js代码也会引起内存泄露的问题。
首先,有如下代码解释下这句话的意思:
1 img.onload = function () { 2 img.onload = img.onerror = null; 3 } 4 $(...).on('keyup', function(e){ 5 $().off(e); 6 })
那这么做有什么好处呢,那么我们看下下面的情况:
3.及时清除引用。
这个习惯也是针对于内存泄露问题,我们先看看以下代码:
1 <!doctype html> 2 <html> 3 <head> 4 <title>Memory leak demo</title> 5 </head> 6 <body> 7 <a href="javascript:;">Click me</a> 8 </body> 9 <script src="jquery-1.8.0.js"></script><script> 10 $('a').click(function callback(e) { 11 $(this).remove(); 12 $('<a href="javascript:;">Click me</a>').appendTo(document.body).click(function(e2){ 13 e2.leak = e; 14 callback.call(this, e2); 15 }); 16 17 var current = e, n = 0; 18 while(current.leak){ 19 current = current.leak; 20 n++; 21 } 22 console.log('leaked: ' + n); 23 //e = null; 24 }); 25 </script> 26 </html>
这是段代码在不停的替换页面中的a标签,并且为新的a标签绑定clcik事件,在事件的回调函数中,引用了上一个事件的e,导致了原本的a标签即使已经被remove也无法被释放,仍然保存在内存里。随着用户click次数的增多,内存泄露问题也会越来越严重。
所以这个时候,我们就要记得及时清除引用,这段代码的内存泄露问题是由于事件对象e引起的,在23行,去掉注释后,e = null 释放了内层函数对外层函数的变量e指向的对象的引用,使得e以及它引用的dom节点能被释放,内存泄露问题也就得以解决了。
当然,想写出高性能的js,还有很多可以仔细研究的地方,而上面的三个习惯是可以在日常的编码中养成的,也没有什么替换成本。还有很多良好的习惯,比如减少函数引用,尽量少使用闭包等。
相关推荐
这三个部分共同构成了现代网页的基础,使得开发者能够创建出既美观又功能丰富的网站。 #### 三、JavaScript的特性和历史 - **特性**: - **跨平台**:JavaScript 可以运行在多种平台上。 - **面向对象**:支持...
- **网络编程**:构建高性能的服务端应用,如WebSocket服务。 - **微服务架构**:利用Express等框架快速搭建RESTful API。 #### 五、工具和框架 1. **开发工具**: - **编辑器**:如Visual Studio Code、...
总的来说,《Effective JavaScript》提供了对JavaScript深入理解的宝贵资源,通过68个具体的方法,它不仅揭示了语言的复杂性,还给出了实用的建议,帮助开发者写出更健壮、更高效的代码。这本书适合所有层次的...
"阶段三-JavaScript高级"这一主题通常涵盖了JavaScript的深入理解和高级应用,包括但不限于原型、闭包、异步编程、模块化、设计模式以及性能优化等多个方面。 1. **原型**:在JavaScript中,对象可以通过原型链相互...
根据题目中的描述,“JavaScript是一种基于对象(Object)和事件驱动(Event Driven)并具有安全性能的脚本语言。”这表明JavaScript不仅能够处理页面上的各种对象,还能响应用户的操作,如点击按钮或移动鼠标等事件。 ...
- **性能优化技巧**:针对JavaScript运行时可能会遇到的性能瓶颈问题,Resig提出了一系列优化策略,例如避免全局变量污染、减少DOM操作等。 - **模块化开发**:随着项目的复杂度增加,模块化成为了一种重要的组织...
7. **函数式编程**:JavaScript也支持函数式编程思想,如高阶函数、纯函数、柯里化和函数组合等,它们可以帮助写出更简洁、可维护的代码。 8. **错误处理**:try...catch语句用于捕获和处理运行时错误,同时理解...
理解和熟练运用这些异步处理方法,可以写出高性能的前端应用。 七、错误处理与调试 了解和处理JavaScript运行时可能出现的错误,如TypeError、RangeError等,以及如何利用console工具、断点和debugger语句进行程序...
- **代码优化**:学习如何写出高效、可维护的代码,避免常见的性能坑。 - **调试技巧**:掌握使用浏览器开发者工具进行调试的方法,快速定位并解决问题。 #### 5. 生态系统与框架 - **Node.js**:了解Node.js的工作...
JavaScript异步编程是Web开发中的核心概念,尤其在构建高性能、响应式的网页应用时不可或缺。深入理解这一主题,对于任何JavaScript开发者来说都是至关重要的。在这个教程中,我们将探索JavaScript异步处理的各个...
理解V8引擎的工作原理,如垃圾回收、编译优化等,有助于编写高性能的JavaScript代码。避免全局查找、减少DOM操作、合理使用缓存等也是优化技巧。 总结,JavaScript的"好零件"包括其灵活的数据类型、强大的函数机制...
这部分内容对于编写高性能、无阻塞的Web应用至关重要,尤其是在处理I/O密集型任务时。 函数式编程是JavaScript中的一个重要主题,书中会介绍函数式编程思想和相关的高阶函数,如map、reduce和filter。这些工具能...
12. **性能优化**:理解V8引擎的工作原理,如对象池、垃圾回收等,可以帮助写出运行更快的JavaScript代码。 13. **跨域问题**:由于同源策略,JavaScript在不同源之间有访问限制,理解JSONP、CORS等跨域解决方案是...
- **高性能的 JavaScript 解析与执行**:利用即时编译(JIT)技术将 JavaScript 代码转换为机器码,从而获得接近原生代码的执行速度。 - **内存管理**:提供了自动化的垃圾回收机制,帮助开发者管理内存,避免常见的...
1. GreenSock (GSAP):这是一个强大的JavaScript动画库,提供了高级的性能和易用性,支持复杂的动画序列和时间线。 2. Anime.js:这是一个轻量级且功能丰富的动画库,支持CSS属性、SVG、DOM、JavaScript对象和数值...
设计模式的学习,则是为了帮助学习者写出更符合工程化要求的代码。 通过这三本书的学习,无论学习者是编程新手还是经验丰富的开发者,都能够全面地提高自己的JavaScript编程能力。初学者可以从基础开始,逐步建立起...
根据提供的文件信息,我们可以推断出这是...掌握其高级用法不仅可以帮助开发者写出更优秀的代码,还可以提升项目的整体质量。通过深入学习上述知识点,可以显著提高个人的技术水平,从而在竞争激烈的IT行业中脱颖而出。
- **编码规范**:提供一系列编码规范建议,帮助开发者写出更高质量的代码。 - **调试工具**:介绍常用的调试工具和技术,如Chrome DevTools,以便快速定位并解决问题。 - **性能优化**:讨论如何优化JavaScript代码...