首页 > web前端 > js教程 > 正文

javascript生成器函数是什么_yield关键字如何控制执行流程?

夢幻星辰
发布: 2025-12-23 12:42:08
原创
216人浏览过
JavaScript生成器函数用function声明,调用返回生成器对象,通过next()暂停/恢复执行并yield按需产出值,支持传参接收、嵌套逻辑及yield委托复用。

javascript生成器函数是什么_yield关键字如何控制执行流程?

JavaScript 生成器函数是一种特殊函数,它能**暂停和恢复执行**,配合 yield 关键字实现按需产出值,常用于处理惰性序列、异步流程控制或状态机场景。

生成器函数的定义与调用方式

function* 语法声明,调用时不立即执行,而是返回一个生成器对象(Generator Object),该对象具备 next()return()throw() 等方法。

  • 生成器函数体内的代码只有在首次调用 next() 时才开始执行
  • 每次遇到 yield 表达式就暂停,并把 yield 后面的值作为 value 返回
  • 后续再次调用 next(),会从上次暂停位置继续执行,直到下一个 yield 或函数结束

yield 如何控制执行流程

yield 不是普通关键字,它是生成器内部的“暂停点”,兼具输出值接收外部输入的能力:

  • yield 表达式本身有返回值:下一次调用 next(arg) 时传入的参数,会成为当前 yield 表达式的计算结果(即 yield 左侧变量接收到的值)
  • yield 可以嵌套在任意逻辑中:比如循环、条件判断、try/catch 内,暂停时机完全由代码结构决定
  • yield* 可委托另一个生成器:让当前生成器“展开”并逐个产出另一个生成器的值,实现组合复用

典型执行流程示例

看这段代码:

星绘
星绘

豆包旗下 AI 写真、P 图、换装和视频生成

星绘 429
查看详情 星绘

立即学习Java免费学习笔记(深入)”;

function* counter() {
  let i = 0;
  while (i < 3) {
    const reset = yield i++;
    if (reset === 'reset') i = 0;
  }
}
登录后复制

执行过程如下:

  • gen.next() → 执行到 yield i++(此时 i=0),暂停,返回 { value: 0, done: false }
  • gen.next() → 继续执行 i++(i 变为 1),再 yield,返回 { value: 1, done: false }
  • gen.next('reset') → i++ 执行后 i=2,但 yield 表达式接收到 'reset',进入 if 分支,i 重置为 0;下次再 next 就又从 0 开始

实际用途提示

生成器不是为替代 for 循环而生,它的价值在于显式暴露控制权

  • 实现自定义迭代器(如树的深度优先遍历)
  • 配合 Promise 封装成 async/await 的早期替代方案(如 co 库)
  • 构建协程式状态管理(例如游戏帧更新、表单多步骤校验)
  • 生成无限序列(如斐波那契数列),靠 yield 惰性求值,避免内存爆炸

以上就是javascript生成器函数是什么_yield关键字如何控制执行流程?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号