迭代器是JavaScript中统一访问集合数据的机制,核心是实现Symbol.iterator方法返回含next()的对象;next()返回{value, done}结构,支持惰性求值与自定义遍历逻辑。

迭代器是 JavaScript 中一种统一访问集合数据的机制,它让对象能按需逐个返回值,并控制遍历过程。核心在于实现 Symbol.iterator 方法,返回一个具有 next() 方法的对象。
迭代器的基本结构
一个合法的迭代器对象必须满足:调用 next() 方法时,返回形如 { value: ..., done: true|false } 的对象。done: true 表示遍历结束;value 是当前产出的值(可以是任意类型,包括 undefined)。
- 每次调用 next() 都应推进内部状态(比如索引、指针或计算逻辑)
- 迭代器可以是惰性的——值只在调用 next() 时才生成,适合处理大数据流或无限序列
- 原生数组、Map、Set、字符串等都内置了 Symbol.iterator,所以能直接用于 for...of、展开运算符等
手动实现一个简单迭代器
比如为一个自定义范围类添加迭代能力:
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 };
}
}
};
}
}
这样就能直接使用:
立即学习“Java免费学习笔记(深入)”;
for (const n of new Range(2, 5)) {
console.log(n); // 输出 2, 3, 4, 5
}
用生成器函数简化迭代器实现
生成器函数(function*)会自动返回符合迭代器协议的对象,大幅降低手写成本:
class Countdown {
constructor(n) {
this.n = n;
}
*[Symbol.iterator]() {
for (let i = this.n; i > 0; i--) {
yield i;
}
}
}
它等价于手动实现但更简洁、可读性更强,还能自然支持 yield* 委托、异步迭代(async function*)等高级特性。
自定义迭代逻辑的关键点
真正灵活的地方在于:你可以完全控制“怎么取下一个值”和“何时停止”。例如:
- 跳过某些元素(如只返回偶数)
- 组合多个数据源(类似迭代器的“链式”拼接)
- 基于异步操作生成值(配合 AsyncIterator 和 for await...of)
- 封装副作用(如日志、节流、缓存)在 next() 内部
只要返回的对象遵循迭代器协议,JavaScript 的所有消费方(for...of、Array.from、...)都能无缝使用。
基本上就这些。迭代器不是语法糖,而是一套可扩展的数据抽象协议——它把“如何遍历”从“遍历什么”中解耦出来,让自定义逻辑既清晰又通用。










