除非您试图挤出每一盎司的性能,否则我会创建一个像这样的过滤器函数:
filter = (list, func) -> x for x in list when func(x)
或者如果你想将它添加到每个数组的原型中:
Array::filter = (func) -> x for x in @ when func(x)
然后写:(分别)
result = filter mylist, (x) -> x % 2 == 0
或者
result = mylist.filter (x) -> x % 2 == 0
作为参考,这是生成的 javascript:
var filter, result;
filter = function(list, func) {
var x, _i, _len, _results;
_results = [];
for (_i = 0, _len = list.length; _i < _len; _i++) {
x = list[_i];
if (func(x)) {
_results.push(x);
}
}
return _results;
};
Array.prototype.filter = function(func) {
var x, _i, _len, _results;
_results = [];
for (_i = 0, _len = this.length; _i < _len; _i++) {
x = this[_i];
if (func(x)) {
_results.push(x);
}
}
return _results;
};
result = filter(mylist, function(x) {
return x % 2 === 0;
});
result = mylist.filter(function(x) {
return x % 2 === 0;
});
这里有一个类似的问题