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

什么是生成器函数_javascript中yield关键字怎么用?

夢幻星辰
发布: 2025-12-12 16:05:34
原创
691人浏览过
生成器函数用function定义,调用返回迭代器;yield交出控制权并返回值,next()可传参赋值给yield表达式;yield委托其他迭代器;常用于自定义迭代、异步处理、无限序列和状态机。

什么是生成器函数_javascript中yield关键字怎么用?

生成器函数是 JavaScript 中一种特殊函数,能**暂停和恢复执行**,适合处理异步流程、大数据流或需要按需计算的场景;yield 是它的核心关键字,用于**交出函数控制权并返回一个值**,下次调用时从暂停处继续。

生成器函数怎么定义和调用?

function*(星号紧贴 function)定义,调用时不立即执行,而是返回一个迭代器对象

示例:

function* count() {
  yield 1;
  yield 2;
  yield 3;
}
const it = count(); // 不执行函数体,只返回迭代器
console.log(it.next()); // { value: 1, done: false }
console.log(it.next()); // { value: 2, done: false }
console.log(it.next()); // { value: 3, done: false }
console.log(it.next()); // { value: undefined, done: true }
登录后复制

yield 怎么交出值并接收外部传入的值?

yield 表达式本身有返回值——即下一次 next(…) 调用时传入的参数。第一次 next() 传参无效(因无上一个 yield 等待接收):

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

  • yield 1 → 返回 {value: 1, done: false},同时暂停
  • it.next('hello') → 'hello' 成为当前 yield 表达式的值,继续执行

常见写法:

Ghiblio
Ghiblio

专业AI吉卜力风格转换平台,将生活照变身吉卜力风格照

Ghiblio 157
查看详情 Ghiblio
function* echo() {
  let input = yield 'ready?';
  console.log(input); // 输出 'got it!'
  yield 'done';
}
const e = echo();
console.log(e.next());        // { value: 'ready?', done: false }
console.log(e.next('got it!')); // 控制台打印 'got it!',返回 { value: 'done', done: false }
登录后复制

yield* 怎么委托另一个生成器或可迭代对象

yield* 用来“展开”另一个迭代器,把它的每个 yield 值依次产出,相当于把控制权暂时转交给它:

  • yield* arr → 等价于对 arr 的每个元素 yield 一次
  • yield* anotherGenerator() → 逐个产出另一个生成器的所有值

例子:

function* nums() {
  yield 1; yield 2;
}
function* all() {
  yield 'start';
  yield* nums(); // 展开
  yield 'end';
}
[...all()]; // ['start', 1, 2, 'end']
登录后复制

实际中生成器常用来做什么?

虽然 async/await 已成主流,但生成器仍有不可替代的用途:

  • 实现自定义迭代逻辑(比如树的深度优先遍历)
  • 配合 co 库或手写 runner 处理异步(早期 redux-saga 就基于它)
  • 生成无限序列(如斐波那契数列),靠 next() 按需取值,不爆内存
  • 状态机建模:每个 yield 代表一个稳定状态,next() 触发状态迁移

基本上就这些。yield 不是魔法,本质是函数执行权的让渡与回收,理解这一点,用起来就不容易卡壳。

以上就是什么是生成器函数_javascript中yield关键字怎么用?的详细内容,更多请关注php中文网其它相关文章!

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

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

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

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