javascript for循环设法提高性能
作者:bea
一般在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
一般在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 移到循环外了。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 使用js获取QueryString的方法小结
- js实现的八点拖动修改div大小的代码
- JavaScript 面向对象代码实践
- Javascript 使用function定义构造函数
- JQuery 将元素显示在屏幕的中央的代码
- JQuery团队打造的javascript单元测试工具QUnit介绍
- getElementsByTagName vs selectNodes效率 及兼容的selectNodes实现
- JavaScript 空位补零实现代码
- javascript replace()正则替换实现代码
- JavaScript 时分秒时间代码(自动补零)
- javascript function调用时的参数检测常用办法
- jquery1.4 教程三 新增方法教程
- jquery1.4 教程二 ajax方法的改进
- jquery1.4 教程一 便利的设置函数
- jquery 1.4.2发布!主要是性能与API
- jQuery 方法大全方便学习参考
- js 面向对象的技术创建高级 Web 应用程序
- javascript 命名规则 变量命名规则
- js 表格拖拽效果实例代码 (IE only)