Ruby能轻易实现的一个功能在JavaScript里用不了,比较让人郁闷:
[1,2,3,4,5].each{|item| puts item; break if item > 3;}
1.6版本的JavaScript为Array实现了一个forEach方法,在MooTools中它有个alias叫each,但用起来不是那么方便,好像没有办法实现上面ruby代码的功能。
[1,2,3,4,5].forEach(function(item){
alert(item);
if(item>3) //return?没效果,只是跳出这个匿名function而已,本来代码就已经执行完了,加个return明显多余。break?没有这样用的。
});
仔细一想,反正这个匿名函数的返回值也没有用处,不如直接用作判断跳出循环的条件吧,于是写出如下代码:
Array.prototype.forEach = function(fn, bind){
for(var i=0; i<this.length; i++){
var result = fn.call(bind, this[i], i, this);
if(result!==undefined && !result) break;
}
};
使用:
example 1
[1,2,3,4,5].forEach(function(item){
alert(item);
});
example 2
[1,2,3,4,5].forEach(function(item, index, arr){
alert('数组['+arr+']的第'+(index+1)+'个元素是'+item);
return item<=3;//返回false则跳出循环
});