迭代器是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、...)都能无缝使用。
基本上就这些。迭代器不是语法糖,而是一套可扩展的数据抽象协议——它把“如何遍历”从“遍历什么”中解耦出来,让自定义逻辑既清晰又通用。