JavaScript性能优化之循环操作
JavaScript中有四种不同类型的循环,for循环、do-while循环和while循环。(第四种类型为for-in循环,用于迭代对象的属性,本文不予讨论。)代码如下:
var values = [1, 2, 3, 4, 5];
//for 循环
for(var i=0; i<values.length; i++){
process(values[i]);
}
//do-while 循环
var j=0;
do{
process(values[j++]);
} while(j < values.length);
//while 循环
var k=0;
while(k < values.length){
process(values[k++]);
}
每个循环示例都会得到相同的结果:将values数组的所有条目传送到process函数。
仔细观察会发现,代码中每次循环执行都会调用 values.length 查看是否到达数组尾部。调用 values.length 查看数组长度是非常低效的,并且在循环执行中并不会改变values数组的长度。 通过使用本地变量替代属性查找将会提高循环的效率。
var values = [1,2,3,4,5];
var length = values.length;
//for 循环
for(var i=0; i<length; i++){
process(values[i]);
}
//do-while 循环
var j=0;
do{
process(values[j++]);
} while(j < length);
//while 循环
var k=0;
while(k < length){
process(values[k++]);
}
现在每个循环使用本地变量 length 替代了 values.length ,从而减少了每次循环执行中属性查找的时间。
另外一种简单的提升循环效率的方法是使用总长度向0递减的方法替代从0向总长度递增的方法。
var values = [1,2,3,4,5];
var length = values.length;
//for 循环
for(var i=length; i--;){
process(values[i]);
}
//do-while 循环
var j=length;
do{
process(values[--j]);
} while(j);
//while 循环
var k=length;
while(k--){
process(values[k]);
}
条件修改为等于0后,每个循环的执行效率有了显著的提高。(当循环变量等于0时,条件判断为true)。
每种循环的执行效率都是相同的,所以你并不需要烦恼选择哪种循环方式效率最高。
相关文档:
ugmbbc发布于 2009-11-14 09:41:43| 7628 次阅读 字体:大 小 打印预览
var ReTitle = '回复:Google 排名中的 10 个最著名的 JavaScript 库';
感谢COMSHARP CMS的投递
新闻来源:tripwiremagazine.com
JavaScript 是 Web 开发与设计中不可或缺的东西,不管是一个简单的网页还是一个专业的站点,也不管你是高手还是菜鸟 ......
6、基于对象的JavaScript语言
JavaScript是基于对象的的语言,不像面向对象有抽象、继承、重载等有关面向对象的功能,但是它还是具有面向对象的基本特征,它可以根据需要创建自己的对象,从而进一步扩大JavaScript的应用范围,增强编写功能强大的Web文档。
对象的基础知识:
对象是由属性和方法两个基本元素组成。一个对 ......
有许多小窍门来使编程更加容易。其中之一就是eval()函数,这个函数可以把一个字符串当作一个JavaScript表达式一样去执行它。以下是它的说明
Eval 函数
功能:先解释Javascript代码,然后在执行它
用法:Eval(codeString)
codeString是包含有Javascript语句的字符串,在eval之后使用Javascript引擎编译。
举个小例子:
......
JS中数组的批量填充方式:
1.在声明时同时进行填充
var beatles = Array("John","Paul","George","Ringo");
2.我们甚至用不着明确地表明我们是在创建数组.事实上,只需用一堆方括号括起来就足以创建我们想要的数组了:
......