迭代器是JavaScript中统一访问集合数据的机制,核心是实现Symbol.iterator方法返回含next()的对象;next()返回{value, done}结构,支持惰性求值与自定义遍历逻辑。
迭代器是 JavaScript 中一种统一访问集合数据的机制,它让对象能按需逐个返回值,并控制遍历过程。核心在于实现 Symbol.iterator 方法,返回一个具有 next() 方法的对象。
一个合法的迭代器对象必须满足:调用 next() 方法时,返回形如 { value: ..., done: true|false } 的对象。done: true 表示遍历结束;value 是当前产出的值(可以是任意类型,包括 undefined)。
比如为一个自定义范围类添加迭代能力:
class Range {
constructor(start, end) {
this.start = start;
this.end = end;
}
[Symbol.iterator]() {
let current = this.start;
return {
next() {
if (current <= this.end) {
return { value: current++, done: false };
} else {
return { value: undefined, done: true };
}
}
};
}
}
这样就能直接使用:
for (const n of new Range(2, 5)) {
console.log(n); // 输出 2, 3, 4, 5
}
生成器函数(function*)会自动返回符合迭代器协议的对象,大幅降低手写成本:
class Countdown {
constructor(n) {
this.n = n;
}
*[Sym
bol.iterator]() {
for (let i = this.n; i > 0; i--) {
yield i;
}
}
}
它等价于手动实现但更简洁、可读性更强,还能自然支持 yield* 委托、异步迭代(async function*)等高级特性。
真正灵活的地方在于:你可以完全控制“怎么取下一个值”和“何时停止”。例如:
只要返回的对象遵循迭代器协议,JavaScript 的所有消费方(for...of、Array.from、...)都能无缝使用。
基本上就这些。迭代器不是语法糖,而是一套可扩展的数据抽象协议——它把“如何遍历”从“遍历什么”中解耦出来,让自定义逻辑既清晰又通用。