JavaScript生成器通过function*定义,使用yield暂停执行并返回值,调用next()恢复运行,适合处理延迟计算与异步流程。
JavaScript 生成器是一种特殊函数,能暂停执行并保留当前状态,之后可恢复。它通过 function* 定义,并使用 yield 暂停函数运行。这种机制适合处理延迟计算、异步流程控制和大数据流场景。
生成器函数用 function* 语法声明,调用时返回一个可迭代的生成器对象,不会立即执行函数体。
function* myGenerator() { yield '第一步'; yield '第二步'; return '结束'; }const gen = myGenerator(); // 此时函数未执行console.log(gen.
next()); // { value: '第一步', done: false }yield 表达式用于暂停函数执行,并将值传出。每次调用生成器的 next() 方法,函数会运行到下一个 yield 或 return。
生成器对象是可迭代的,因此可以用 for...of 循环自动遍历所有 yield 值,直到 done 为 true。
function* colors() { yield '红'; yield '绿'; yield '蓝'; }for (const color of colors()) { console.log(color); // 依次输出:红、绿、蓝 }注意:for...of 不会遍历 return 的值,除非使用扩展语法 [...colors()],但 return 值仍不会包含在数组中。
生成器适用于需要逐步产生数据或控制执行节奏的场景。
基本上就这些。function* 和 yield 提供了灵活的控制流手段,理解其惰性求值特性对高效使用很关键。