编写高性能Javascript

多年来,Javascript一直在web应用开发中占据重要的地位,但是很多开发者往往忽视一些性能方面的知识,特别是随着计算机硬件的不断升级,开发者越发觉得Javascript性能优化的好不好对网页的执行效率影响不明显。但在某些情况下,不优化的Javascript代码必然会影响用户的体验。因此,即使在当前硬件性能已经大大提升的时代,在编写Javascript代码时,若能遵循Javascript规范和注意一些性能方面的知识,对于提升代码的可维护性和优化性能将大有好处。

  下面给出编写高性能的Javascript代码的若干建议:

  1、尽量不要用for-in 循环去访问数组,建议用 for 循环进行循环: 

 1        function foo1() {
2 var i, b, c=[1,2,3];
3 for (i in c) {
4 b = c[i];
5 if(b === "2")
6 return b;
7 }
8 }
9 //性能更好
10 function foo2() {
11 var i, b, c=[1,2,3];
12 for (i=0;i<c.length;i++) {
13 b = c[i];
14 if(b === "2")
15 return b;
16 }
17
18 }

  2、建议将对象进行缓存处理,特别是DOM访问是比较消耗资源的:

 1     //c.length没有缓存,每次迭代都要计算一下数组的长度
2 function foo1() {
3 var i, b, c=[1,2,3];
4 for (i=0;i<c.length;i++) {
5 b = c[i];
6 if(b === "2")
7 return b;
8 }
9 }
10 //性能更好,第一次将数组的长度缓存到变量l中,第二次及后续的循环无需计算数组长度
11 function foo2() {
12 var i, b, c=[1,2,3],l;
13 for (i=0,l=c.length;i<l;i++) {
14 b = c[i];
15 if(b === "2")
16 return b;
17 }
18 }
 1     //document.getElementById('info')没有缓存,每次都要遍历DOM
2 function foo1() {
3 var e;
4 document.getElementById('info').innerHTML="call 1";
5 document.getElementById('info').innerHTML="call 2";
6
7 }
8 //性能更好,第二次无需访问DOM
9 function foo2() {
10 var e=document.getElementById('info');
11 e.innerHTML="call 1";
12 e.innerHTML="call 2";
13 }

  3、建议不要在函数内进行过深的嵌套判断:

      //函数内嵌套判断语句过多
function foo1() {
var r={};
r.data={};
r.data.myProp=2;
if (r) {
if (r.data) {
if (r.data.myProp) {
//逻辑处理
}
else {
//逻辑处理
}
}
} }
//性能更好
function foo2() {
var r={};
r.data={};
r.data.myProp=2;
if (!r) return;
if (!r.data) return;
if (r.data.myProp) {
//逻辑处理
} else {
//逻辑处理
}
}

  4、避免循环引用,防止内存泄漏:

 1 //需要jQuery
2 function foo1(e,d) {
3 $(e).on("click", function() {
4 //对d进行逻辑处理
5 cbk(d);
6 }
7 });
8 }
9
10 //打破循环!
11 function foo2(e, d) {
12 $(e).on("click", cbk(d));
13 }
14 function cbk (d) {
15 //逻辑处理
16 }

  5、建议避免在函数内返回一个未声明的变量,会污染外部变量:

1 function foo(a, b) {
2 r = a + b;
3 return r; //r未声明,则创建了一个全局变量
4 }

  6、var声明变量,建议写在多行

 1 //自己测试结果是foo1快,但也有一种观点是foo2快
2 function foo1() {
3 var c = 1;
4 var sum=0;
5 var d = 0;
6 var e;
7 }
8
9 function foo2() {
10 var c = 1,sum=0, d = 0, e;
11 }

说明:其实单个函数时间上差别较小,这里采用循环多次用累计时间进行性能对比,不同PC配置或者浏览器测试结果可能存在差异。

水平有限,望各位园友不吝赐教!如果觉得不错,请点击推荐和关注! 
出处:http://www.cnblogs.com/isaboy/ 

编写高性能Javascript的更多相关文章

  1. 编写高性能Javascript代码的若干建议

    多年来,Javascript一直在web应用开发中占据重要的地位,但是很多开发者往往忽视一些性能方面的知识,特别是随着计算机硬件的不断升级,开发者越发觉得Javascript性能优化的好不好对网页的执 ...

  2. 【JavaScript】【译】编写高性能JavaScript

    英文链接:Writing Fast, Memory-Efficient JavaScript 很多JavaScript引擎,如Google的V8引擎(被Chrome和Node所用),是专门为需要快速执 ...

  3. 编写高性能JavaScript【转】

    英文链接:Writing Fast, Memory-Efficient JavaScript 很多JavaScript引擎,如Google的V8引擎(被Chrome和Node所用),是专门为需要快速执 ...

  4. 《高性能javascript》 领悟随笔之-------DOM编程篇(二)

    <高性能javascript> 领悟随笔之-------DOM编程篇二 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

  5. 《高性能javascript》 领悟随笔之-------DOM编程篇

    <高性能javascript> 领悟随笔之-------DOM编程篇一 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

  6. 高性能JavaScript(您值得一看)

    众所周知浏览器是使用单进程处理UI更新和JavaScript运行等多个任务的,而同一时间只能有一个任务被执行,如此说来,JavaScript运行了多长时间就意味着用户得等待浏览器响应需要花多久时间. ...

  7. 【读书笔记】读《高性能JavaScript》

    这本<高性能JavaScript>讲述了有关JavaScript性能优化的方方面面,主要围绕以下几个方面: 1> 加载顺序 2> 数据访问(如怎样的数据类型访问最快,怎样的作用 ...

  8. 《高性能javascript》学习总结

    本文是学习<高性能javascript>(Nichols C. Zakes著)的一些总结,虽然书比较过时,里面的知识点也有很多用不上了,但是毕竟是前人一步步探索过来的,记录着javascr ...

  9. 《高性能Javascript》 Summary(二)

    第四章.算法和流程控制 Algorithms And Flow Control 原因:代码整体结构是执行速度的决定因素之一.代码量少不一定运行速度快,代码量多不一定运行速度慢.性能损失与组织代码和具体 ...

随机推荐

  1. u-boot 的bootcmd 和bootargs详解,烧写分析

    下面链接这篇文章也非常重要,介绍DM3X的一系列烧写步骤和设置方法 http://www.61ic.com/Article/DaVinci/TMS320DM3x/201204/41827.html U ...

  2. An Overview of Complex Event Processing2

    An Overview of Complex Event Processing 翻译前言:感觉作者有点夸夸其谈兼絮絮叨叨,但文章还是很有用的.原文<An Overview of Complex ...

  3. WPF命令參数CommandParameter

    XAML代码例如以下: <Window x:Class="Demo006.MainWindow" xmlns="http://schemas.microsoft.c ...

  4. [C++] WinAES问题

    WinAES这是一个很好windows CAPI包. 假设C++项目需求和java程序aes加密和通信的解密,然后WinAES代码是有问题. java的aes默认代码未设置IV和用途ECB模式. 因此 ...

  5. awk与sed:关于多行的样本

    几天前CSDN看到一个帖子http://bbs.csdn.net/topics/390848841,楼主贴了以下的问题: 例: 12345 67890 1234567890 123 4567890 怎 ...

  6. Test SRM Level Three: LargestCircle, Brute Force

    题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=3005&rd=5858 思路: 如果直接用Brute F ...

  7. A WPF/MVVM Countdown Timer

    Introduction This article describes the construction of a countdown timer application written in C# ...

  8. 构建工具maven

     构建工具maven  =UTF-8''Gradle Effective Implementation Guide.pdf: http://www.t00y.com/file/76854506 b ...

  9. define a class for a linked list and write a method to delete the nth node.

    1.问题 define a class for a linked list and write a method to delete the nth node. 2.算法 template <t ...

  10. HTML——博客页面布局

    HTML文件 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/htm ...