JavaScript生成器函数与yield使用详解
时间:2026-01-19 13:54:44 354浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《JavaScript生成器函数与yield用法解析》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
生成器函数用function*声明,调用后返回Generator对象且不立即执行;需调用next()启动或恢复,遇yield暂停并返回值,状态保留,终止后next()恒返{value:undefined,done:true}。

生成器函数声明和调用后不立即执行
生成器函数不是普通函数,它用 function* 声明,调用后返回一个 Generator 对象,而不是直接运行函数体。这个对象是“可迭代的”,但内部状态初始为 suspended —— 什么都没执行。
必须显式调用 next() 才会启动或恢复执行,直到遇到第一个 yield 或函数结束。
function* count() {
console.log('start');
yield 1;
console.log('after first yield');
yield 2;
}
const gen = count(); // ← 此时 'start' 还没打印
gen.next(); // → { value: 1, done: false },同时打印 'start'
gen.next(); // → { value: 2, done: false },同时打印 'after first yield'yield 是暂停点,不是返回值语句
yield 暂停函数执行,并把右侧表达式的值作为 next() 返回对象的 value。函数上下文(变量、执行位置)被完整保留,下次 next() 从下一行继续。
yield右侧表达式只在本次next()调用时求值- 如果
yield后面没有值(如yield;),value为undefined yield表达式本身的结果,是下一次next(value)传入的value(可用于双向通信)
function* echo() {
const a = yield 'first';
console.log('a =', a); // ← 下次 next(123) 传入的 123 在这里接收
const b = yield 'second';
return b * 2;
}
const g = echo();
g.next(); // → { value: 'first', done: false }
g.next(123); // → { value: 'second', done: false },并打印 'a = 123'
g.next(456); // → { value: 912, done: true }生成器终止后再次调用 next() 总是返回 { value: undefined, done: true }
一旦生成器函数 return(显式或隐式)或抛出未捕获错误,状态变为 closed。此后所有 next() 调用都返回固定结果,不会重跑、不会报错、也不会触发 finally 块(如果有的话)。
- 多次
next()不会重复执行return后的代码 throw()或return()也可提前终止,效果等同于自然结束- 已终止的生成器无法重用,必须重新调用生成器函数创建新实例
function* once() {
yield 1;
return 'done';
}
const g = once();
g.next(); // → { value: 1, done: false }
g.next(); // → { value: 'done', done: true }
g.next(); // → { value: undefined, done: true } ← 不变
g.next(); // → { value: undefined, done: true } ← 依然不变生成器常用于实现惰性序列和异步流程控制
因为能暂停/恢复且保持状态,生成器天然适合封装「按需计算」逻辑,比如无限数列、文件逐块读取;配合 async/await(如 co 库或手动包装),还能模拟协程式异步写法。
- 避免一次性生成大数据集,节省内存
- 与
for...of、展开语法[...gen]、Array.from(gen)配合使用最自然 - 注意:原生
async function*是异步迭代器,和同步生成器行为不同,不要混用yield和await在同一个函数里(除非用async function*)
真正容易被忽略的是:生成器函数内部的 try...finally 块,在 return 或 throw 终止时会执行,但在外部多次调用 next() 导致的「静默终止」中,finally 只触发一次 —— 就是那个让状态变成 done: true 的那次调用。
今天关于《JavaScript生成器函数与yield使用详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
192 收藏
-
319 收藏
-
129 收藏
-
177 收藏
-
217 收藏
-
127 收藏
-
126 收藏
-
411 收藏
-
124 收藏
-
319 收藏
-
135 收藏
-
393 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习