0

0

JS中的Generator函数是什么?如何使用?

下次还敢

下次还敢

发布时间:2025-06-05 22:00:02

|

798人浏览过

|

来源于php中文网

原创

generator函数是javascript中一种能分段执行并保持状态的特殊函数,通过function*定义,使用yield暂停执行,适合处理异步操作、懒加载和逐步返回结果。它在调用时不立即执行函数体,而是返回一个generator对象,通过.next()方法逐步执行,每次遇到yield或return暂停;其中return标记done: true,而yield为done: false。generator可通过配合promise实现类似同步的异步流程控制,如异步任务按顺序执行;也可用于创建自定义迭代器,例如无限递增数字生成器。此外,支持通过.next(value)传值、.throw(error)触发错误及使用yield*代理其他generator,提供了灵活的代码执行控制方式。

JS中的Generator函数是什么?如何使用?

Generator函数是JavaScript中一种特殊的函数,它和普通函数不同,可以在执行过程中暂停,并在之后恢复执行。这种“可暂停”的特性让它非常适合用来处理异步操作、懒加载数据、或者需要逐步返回结果的场景。


什么是Generator函数?

Generator函数本质上是一种能分段执行并保持状态的函数。它不会像普通函数那样一调用就从头执行到尾,而是可以在执行过程中通过 yield 暂停,在外部控制下继续执行下一步。

定义方式是在函数关键字 function 后加一个星号 *,例如:

function* myGenerator() {
  yield 1;
  yield 2;
  return 3;
}

当你调用这个函数时,它并不会立即执行函数体,而是返回一个Generator对象,你可以通过这个对象手动控制执行进度。


如何使用Generator函数?

基本用法:一步步执行

调用 .next() 方法可以让Generator函数从当前暂停的位置继续执行,直到遇到下一个 yieldreturn

const gen = myGenerator();
console.log(gen.next()); // { value: 1, done: false }
console.log(gen.next()); // { value: 2, done: false }
console.log(gen.next()); // { value: 3, done: true }
  • value 是当前 yieldreturn 的值。
  • done 表示函数是否已经执行完毕。
注意:只有 return 的值才会标记为 done: true,而 yield 返回的是 done: false。

Generator配合异步操作

虽然现在Promise和async/await更常见,但在早期JS中,Generator常被用来模拟异步流程控制。

家电小商城网站源码1.0
家电小商城网站源码1.0

家电公司网站源码是一个以米拓为核心进行开发的家电商城网站模板,程序采用metinfo5.3.9 UTF8进行编码,软件包含完整栏目与数据。安装方法:解压上传到空间,访问域名进行安装,安装好后,到后台-安全与效率-数据备份还原,恢复好数据后到设置-基本信息和外观-电脑把网站名称什么的改为自己的即可。默认后台账号:admin 密码:132456注意:如本地测试中127.0.0.1无法正常使用,请换成l

下载

比如,你可以写一个异步任务,每次 yield 等待一个异步操作完成:

function asyncTask(time) {
  return new Promise(resolve => setTimeout(resolve, time));
}

function* taskRunner() {
  console.log('开始任务1');
  yield asyncTask(1000).then(() => console.log('任务1完成'));

  console.log('开始任务2');
  yield asyncTask(500).then(() => console.log('任务2完成'));
}

const runner = taskRunner();
runner.next().value.then(() => runner.next().value);

虽然看起来有点绕,但这种方式让异步逻辑看起来像是同步写的,便于管理流程。


用Generator实现自定义迭代器

由于Generator默认返回一个可迭代对象,所以你很容易用它来创建一个自定义的数据生成器。

比如,实现一个无限递增的数字生成器:

function* numberGenerator(start = 0) {
  let i = start;
  while (true) {
    yield i++;
  }
}

const nums = numberGenerator(5);
console.log(nums.next().value); // 5
console.log(nums.next().value); // 6
console.log(nums.next().value); // 7

这种模式非常适合用于懒加载、流式数据处理等场景。


小贴士:几个常用技巧

  • 可以通过 .next(value) 向Generator内部传值,影响后续执行。
  • 使用 .throw(error) 可以在Generator内部触发错误捕获。
  • Generator可以嵌套使用,通过 yield* anotherGenerator() 来代理另一个Generator。

基本上就这些。Generator不是最常用的语法,但它提供了一种灵活的方式来控制代码的执行节奏,在某些特定场景下还是挺有用的。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

296

2023.10.25

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

512

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5306

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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