`
talentluke
  • 浏览: 604519 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

写出高性能javascript----三个习惯

 
阅读更多

做了这么久的前端工程师,总被朋友问到怎么写出高性能的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 })

 

  那这么做有什么好处呢,那么我们看下下面的情况:

 

   比如一个div的keyup和click事件。如果keyup事件引用了div,div又引用着click,那么keyup就会引用 click,如果click引用另一个div的keyup,就会导致内存泄露,解绑keyup或者click任何一者都会消除内存泄露。

 

  而如果不及时释放回调函数,亦有可能发生以上的问题。

 

  上面那段话是不是逻辑很复杂呢^ ^,总之养成这个习惯是不会错的,那就是及时释放回调函数,解除事件绑定。

 

 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,还有很多可以仔细研究的地方,而上面的三个习惯是可以在日常的编码中养成的,也没有什么替换成本。还有很多良好的习惯,比如减少函数引用,尽量少使用闭包等。

分享到:
评论

相关推荐

    高级软件人才培训专家-day02-JavaScript-Vue

    这三个部分共同构成了现代网页的基础,使得开发者能够创建出既美观又功能丰富的网站。 #### 三、JavaScript的特性和历史 - **特性**: - **跨平台**:JavaScript 可以运行在多种平台上。 - **面向对象**:支持...

    JavaScript-关于JavaScript的学习了解

    - **网络编程**:构建高性能的服务端应用,如WebSocket服务。 - **微服务架构**:利用Express等框架快速搭建RESTful API。 #### 五、工具和框架 1. **开发工具**: - **编辑器**:如Visual Studio Code、...

    Effective JavaScript 编写高质量JavaScript代码的68个有效方法1

    总的来说,《Effective JavaScript》提供了对JavaScript深入理解的宝贵资源,通过68个具体的方法,它不仅揭示了语言的复杂性,还给出了实用的建议,帮助开发者写出更健壮、更高效的代码。这本书适合所有层次的...

    03-阶段三-JavaScript高级(ppt).zip

    "阶段三-JavaScript高级"这一主题通常涵盖了JavaScript的深入理解和高级应用,包括但不限于原型、闭包、异步编程、模块化、设计模式以及性能优化等多个方面。 1. **原型**:在JavaScript中,对象可以通过原型链相互...

    JavaScript教程--从入门到精通

    根据题目中的描述,“JavaScript是一种基于对象(Object)和事件驱动(Event Driven)并具有安全性能的脚本语言。”这表明JavaScript不仅能够处理页面上的各种对象,还能响应用户的操作,如点击按钮或移动鼠标等事件。 ...

    jquery之父写的javascript

    - **性能优化技巧**:针对JavaScript运行时可能会遇到的性能瓶颈问题,Resig提出了一系列优化策略,例如避免全局变量污染、减少DOM操作等。 - **模块化开发**:随着项目的复杂度增加,模块化成为了一种重要的组织...

    JavaScript-Advanced:JavaScript高级和JavaScript应用程序主题和练习

    7. **函数式编程**:JavaScript也支持函数式编程思想,如高阶函数、纯函数、柯里化和函数组合等,它们可以帮助写出更简洁、可维护的代码。 8. **错误处理**:try...catch语句用于捕获和处理运行时错误,同时理解...

    JavaScript内核系列 pdf

    理解和熟练运用这些异步处理方法,可以写出高性能的前端应用。 七、错误处理与调试 了解和处理JavaScript运行时可能出现的错误,如TypeError、RangeError等,以及如何利用console工具、断点和debugger语句进行程序...

    JavaScript语言精粹 pdf

    - **代码优化**:学习如何写出高效、可维护的代码,避免常见的性能坑。 - **调试技巧**:掌握使用浏览器开发者工具进行调试的方法,快速定位并解决问题。 #### 5. 生态系统与框架 - **Node.js**:了解Node.js的工作...

    深入理解JavaScript异步

    JavaScript异步编程是Web开发中的核心概念,尤其在构建高性能、响应式的网页应用时不可或缺。深入理解这一主题,对于任何JavaScript开发者来说都是至关重要的。在这个教程中,我们将探索JavaScript异步处理的各个...

    test-javascript-the-good-parts:JavaScript

    理解V8引擎的工作原理,如垃圾回收、编译优化等,有助于编写高性能的JavaScript代码。避免全局查找、减少DOM操作、合理使用缓存等也是优化技巧。 总结,JavaScript的"好零件"包括其灵活的数据类型、强大的函数机制...

    JavaScript 高级程序设计第三版中文版

    这部分内容对于编写高性能、无阻塞的Web应用至关重要,尤其是在处理I/O密集型任务时。 函数式编程是JavaScript中的一个重要主题,书中会介绍函数式编程思想和相关的高阶函数,如map、reduce和filter。这些工具能...

    300个JavaScript的小例子

    12. **性能优化**:理解V8引擎的工作原理,如对象池、垃圾回收等,可以帮助写出运行更快的JavaScript代码。 13. **跨域问题**:由于同源策略,JavaScript在不同源之间有访问限制,理解JSONP、CORS等跨域解决方案是...

    Google V8学习手记,月javascript写服务器端是多少人的梦醒呀,Google v8让javascript和php一样

    - **高性能的 JavaScript 解析与执行**:利用即时编译(JIT)技术将 JavaScript 代码转换为机器码,从而获得接近原生代码的执行速度。 - **内存管理**:提供了自动化的垃圾回收机制,帮助开发者管理内存,避免常见的...

    javascript 制作动画

    1. GreenSock (GSAP):这是一个强大的JavaScript动画库,提供了高级的性能和易用性,支持复杂的动画序列和时间线。 2. Anime.js:这是一个轻量级且功能丰富的动画库,支持CSS属性、SVG、DOM、JavaScript对象和数值...

    JavaScript 高清pdf 3件套

    设计模式的学习,则是为了帮助学习者写出更符合工程化要求的代码。 通过这三本书的学习,无论学习者是编程新手还是经验丰富的开发者,都能够全面地提高自己的JavaScript编程能力。初学者可以从基础开始,逐步建立起...

    javascript高级教程2.txt

    根据提供的文件信息,我们可以推断出这是...掌握其高级用法不仅可以帮助开发者写出更优秀的代码,还可以提升项目的整体质量。通过深入学习上述知识点,可以显著提高个人的技术水平,从而在竞争激烈的IT行业中脱颖而出。

    JavaScript Bible 第6版

    - **编码规范**:提供一系列编码规范建议,帮助开发者写出更高质量的代码。 - **调试工具**:介绍常用的调试工具和技术,如Chrome DevTools,以便快速定位并解决问题。 - **性能优化**:讨论如何优化JavaScript代码...

Global site tag (gtag.js) - Google Analytics