迭代方法优于循环

在使用for循环时,有时会在确定循环的终止条件时引入一些简单的错误,但是在ES5中,提供了一些更为便利的方法,可以在一些情况下替代for循环,例如数组对象中的原型方法:Array.proptotype.forEach。

for(var i=0,n=players.length;i
我们可以用以下代码替换上面的循环:

players.forEach(function(p){
    p.score++;
});
使用forEach迭代不仅使得代码更为简单,也消除了for循环的终止条件和任何的数组索引。

当我们需要对某个数组中的每个元素进行操作,再重新建立数组时,如果用循环实现:

var trimmed = [];
for(var i=0,n=input.length;i
但是ES5中又引入了Array.prototype.map方法:

var trimmed = input.map(function(s){
    return s.trim();
});

当我们需要提取原数组中的一些满足条件的元素组成一个新的数组时,可以使用Array.prototype.filter:

listings.filter(function(listing){
    return listing.price>=min&&listing.price<=max;
});
但是循环有一点比迭代函数更好,那就是循环可以通过break和continue控制,但是迭代函数不可以,例如,forEach可以通过抛出异常来终止循环,但是这样的话使得forEach效率会变得低下。
所以最后总结:

1.使用迭代方法替换for循环使得代码更可读,避免重复写循环控制逻辑。

2.但当在需要对循环进行有条件终止或控制时,还是使用for循环。




你可能感兴趣的:(迭代方法优于循环)