什么是javascript的生成器函数_yield关键字如何控制执行流程
发布时间 - 2026-01-10 00:00:00 点击率:次生成器函数用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
# java
# 大数据
# ai
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何生成URL和重定向?(路由助手函数)
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何在建站宝盒中设置产品搜索功能?
在centOS 7安装mysql 5.7的详细教程
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
如何构建满足综合性能需求的优质建站方案?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
如何在建站之星绑定自定义域名?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
装修招标网站设计制作流程,装修招标流程?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
如何用美橙互联一键搭建多站合一网站?
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
如何在IIS中新建站点并配置端口与物理路径?
免费视频制作网站,更新又快又好的免费电影网站?
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel怎么清理缓存_Laravel optimize clear命令详解
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
python中快速进行多个字符替换的方法小结
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
,交易猫的商品怎么发布到网站上去?
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
JavaScript中的标签模板是什么_它如何扩展字符串功能
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
iOS中将个别页面强制横屏其他页面竖屏
历史网站制作软件,华为如何找回被删除的网站?
高端建站如何打造兼具美学与转化的品牌官网?
如何用西部建站助手快速创建专业网站?
Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧
JS弹性运动实现方法分析
原生JS实现图片轮播切换效果
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
jQuery中的100个技巧汇总
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
bing浏览器学术搜索入口_bing学术文献检索地址
香港服务器WordPress建站指南:SEO优化与高效部署策略
郑州企业网站制作公司,郑州招聘网站有哪些?
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
如何在IIS中新建站点并配置端口与IP地址?
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
公司门户网站制作流程,华为官网怎么做?
网站建设要注意的标准 促进网站用户好感度!
如何注册花生壳免费域名并搭建个人网站?


nction* 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 }