有没有什么办法map
/ reduce
/ filter
的/ etc Set
中的JavaScript或者我会写我自己?
这是一些明智的Set.prototype
扩展
Set.prototype.map = function map(f) {
var newSet = new Set();
for (var v of this.values()) newSet.add(f(v));
return newSet;
};
Set.prototype.reduce = function(f,initial) {
var result = initial;
for (var v of this) result = f(result, v);
return result;
};
Set.prototype.filter = function filter(f) {
var newSet = new Set();
for (var v of this) if(f(v)) newSet.add(v);
return newSet;
};
Set.prototype.every = function every(f) {
for (var v of this) if (!f(v)) return false;
return true;
};
Set.prototype.some = function some(f) {
for (var v of this) if (f(v)) return true;
return false;
};
让我们来一点
let s = new Set([1,2,3,4]);
还有一些愚蠢的小功能
const times10 = x => x * 10;
const add = (x,y) => x + y;
const even = x => x % 2 === 0;
看看他们如何运作
s.map(times10); //=> Set {10,20,30,40}
s.reduce(add, 0); //=> 10
s.filter(even); //=> Set {2,4}
s.every(even); //=> false
s.some(even); //=> true
那不是很好吗?是的,我也这么认为。将其与丑陋的迭代器用法进行比较
// puke
let newSet = new Set();
for (let v in s) {
newSet.add(times10(v));
}
和
// barf
let sum = 0;
for (let v in s) {
sum = sum + v;
}
有没有更好的方法来完成map
和reduce
使用Set
JavaScript?
@BartekBanachewicz是的,这是个问题...对吗?
—
谢谢您
好吧,考虑一下
—
Bartek Banachewicz
var s = new Set([1,2,3,4]); s.map((a) => 42);
。它改变了元素的数量,map
通常不应该这样做。更糟糕的是,如果只比较保留的对象的一部分,因为从技术上讲,这并不确定要获得哪个对象。
我曾经考虑过,但是我不确定(个人)会认为那是无效的。好的,至少
—
谢谢您
forEach
在这种情况下存在,但是为什么不reduce
呢?
Set
的问题在于Set不是Functor。