javascript for循环设法提高性能
作者:
让你的for循环提升性能的写法,需要的朋友可以参考下。
一般在javascript里对数组进行遍历一般是使用for循环,像下面一样
var arr = [];
for(var i=0; i<arr.length; i++){
//loop
}
这种代码最大的问题,就在于每次循环时都要通过 .操作符获取 .length,增加了开销。那么我们可以这样改进。
var arr = [];
for(var i=0, n=arr.length; i<n; i++){
//loop
}
这样子,先把 arr.length暂存到 n 变量中去。只在开始时获取一次。
但是这样就没问题了吗?貌似多定义了个无意义的变量 n 。好那继续改进
var arr = [];
for(var i=arr.length-1; i > -1; i--){
//loop
}
好这样子,我们把这个循环顺序倒过来,就把那个n去掉了,而使用了一个常量-1。
如果应用场景,允许不使用 for 循环的话。我们可在使用 while代替
善于使用这两种循环语句,以提高javascript的效率。
var arr = [];
var i=arr.length-1;
while(i--){
//loop arr[i]
}
或者
var arr = [];
var i=arr.length-1;
do {
// loop arr[i]
}while(--i)
这样代码更简洁,效率更好,特别是如果允许先执行一次循环体的情况下,使用do while效果很明显。
唯一的问题是把 i 移到循环外了。
复制代码 代码如下:
var arr = [];
for(var i=0; i<arr.length; i++){
//loop
}
这种代码最大的问题,就在于每次循环时都要通过 .操作符获取 .length,增加了开销。那么我们可以这样改进。
复制代码 代码如下:
var arr = [];
for(var i=0, n=arr.length; i<n; i++){
//loop
}
这样子,先把 arr.length暂存到 n 变量中去。只在开始时获取一次。
但是这样就没问题了吗?貌似多定义了个无意义的变量 n 。好那继续改进
复制代码 代码如下:
var arr = [];
for(var i=arr.length-1; i > -1; i--){
//loop
}
好这样子,我们把这个循环顺序倒过来,就把那个n去掉了,而使用了一个常量-1。
如果应用场景,允许不使用 for 循环的话。我们可在使用 while代替
善于使用这两种循环语句,以提高javascript的效率。
复制代码 代码如下:
var arr = [];
var i=arr.length-1;
while(i--){
//loop arr[i]
}
或者
复制代码 代码如下:
var arr = [];
var i=arr.length-1;
do {
// loop arr[i]
}while(--i)
这样代码更简洁,效率更好,特别是如果允许先执行一次循环体的情况下,使用do while效果很明显。
唯一的问题是把 i 移到循环外了。
您可能感兴趣的文章:
- jQuery的Each比JS原生for循环性能慢很多的原因
- JS常用的几种数组遍历方式以及性能分析对比实例详解
- JavaScript遍历数组的三种方法map、forEach与filter实例详解
- JS数组的遍历方式for循环与for...in
- js中的for如何实现foreach中的遍历
- JavaScript中的数组遍历forEach()与map()方法以及兼容写法介绍
- JavaScript forEach()遍历函数使用及介绍
- javascript forEach通用循环遍历方法
- JS 使用for循环遍历子节点查找元素
- JavaScript中for-in遍历方式示例介绍
- javascript for循环性能测试示例