生成器/迭代器允许操作对象序列,而不必首先构建所有序列项。这样可以节省机器的内存空间。
像
map
、reduce
、find
、forEach
等数组方法在函数式编程中是必不可少的,因为它允许将代码编写为纯函数序列,更易于测试等。
我想要一个公平的解决方案,让我使用生成器/迭代器和数组函数。
让我们看一下这段代码:
function* myGen() {
yield 1;
yield 2;
yield 3;
throw new Error('oups');
}
const y = [...myGen()].find(x => x > 2);
assert.deepStrictEqual(y, 3);
这不起作用因为首先发生扩展,占用所有内存空间,并且生成器函数将一直运行到结束并抛出异常。
在这个例子中,我希望Javascript首先执行
find
函数的代码,在每个下一个迭代器计算之前执行foreach元素。
我想要一个允许我使用数组方法的解决方案,而无需先构建完整的数组。在 JavaScript 中可以吗?
从 ECMAScript 2025 开始,我们有了那些 迭代器辅助方法,并且可以在不将所有内容收集到数组中的情况下完成此操作:
function* myGen() {
yield 1;
yield 2;
yield 3;
throw new Error('oups');
}
const y = myGen().find(x => x > 2);
console.log(y); // 3
这里
find
不是一个数组方法,而是一个迭代器辅助方法。同样,我们得到 filter
、map
、forEach
和 reduce
作为迭代器辅助方法:
function* myGen() {
yield 1;
yield 2;
yield 3;
throw new Error('oups');
}
const y = myGen().map(x => x * x) // Map to square
.filter(x => x % 2) // Filter odd squares
.take(2) // Only get two results
.reduce((sum, x) => sum + x); // Add them together
console.log(y); // 10 (1 + 9)