0

0

JavaScript中的异步迭代器与生成器如何结合使用?

紅蓮之龍

紅蓮之龍

发布时间:2025-09-27 11:39:01

|

199人浏览过

|

来源于php中文网

原创

异步生成器通过async function*定义,结合for await...of可优雅处理异步数据流,如分页请求、事件流等场景,自动实现异步迭代器协议,简化异步序列操作。

javascript中的异步迭代器与生成器如何结合使用?

异步迭代器与生成器结合使用,可以让开发者更优雅地处理异步数据流。JavaScript中的async function*语法正是为此设计的。通过在生成器函数前加上async关键字,可以创建一个异步生成器,它返回一个符合异步迭代器协议的对象。

异步生成器的基本用法

异步生成器函数使用 async function* 定义,可以在其中使用 await 并通过 yield 返回异步结果。

  • 每次调用 yield 可以返回一个 Promise,自动被包装为异步迭代项
  • 函数体内的 await 可用于等待异步操作完成
  • 返回的异步迭代器可通过 for await...of 消费

示例:模拟逐个获取远程数据

async function* fetchUsers() {
  const userIds = [1, 2, 3, 4];
  for (const id of userIds) {
    const response = await fetch(`/api/users/${id}`);
    const user = await response.json();
    yield user;
  }
}
<p>// 使用 for await...of 遍历
for await (const user of fetchUsers()) {
console.log(user.name);
}

异步迭代器协议详解

一个异步迭代器需实现 next() 方法,该方法返回一个 Promise,Promise 的结果是 { value, done } 结构。

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

Krea AI
Krea AI

多功能的一站式AI图像生成和编辑平台

下载
  • value 是当前产出的值
  • done 表示是否已结束(true 表示结束)
  • 异步生成器自动实现了这个协议

手动实现一个异步迭代器虽然可行,但使用异步生成器更简洁:

async function* countdown(from) {
  for (let i = from; i > 0; i--) {
    await new Promise(resolve => setTimeout(resolve, 1000));
    yield i;
  }
}
<p>for await (const tick of countdown(3)) {
console.log(tick); // 每秒输出 3, 2, 1
}

实际应用场景

这种组合特别适合处理分页数据、事件流或需要延迟处理的队列任务。

  • 读取大型日志文件时,按块异步加载并处理
  • 从 WebSocket 或 SSE 流中持续接收消息
  • 实现带背压的数据管道

例如,处理分页 API:

async function* paginatedAPI(url) {
  let page = 1;
  while (true) {
    const res = await fetch(`${url}?page=${page}`);
    const data = await res.json();
    if (data.items.length === 0) break;
    for (const item of data.items) {
      yield item;
    }
    page++;
  }
}
<p>for await (const item of paginatedAPI('/logs')) {
console.log(item);
}

基本上就这些。异步生成器简化了异步序列的构建和消费,配合 for await...of 能写出清晰且高效的流式代码。不复杂但容易忽略的是,每个 yield 的值会被自动 Promise 化,无需手动包装。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

499

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

166

2023.10.07

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

337

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

427

2023.10.12

Golang WebSocket与实时通信开发
Golang WebSocket与实时通信开发

本专题系统讲解 Golang 在 WebSocket 开发中的应用,涵盖 WebSocket 协议、连接管理、消息推送、心跳机制、群聊功能与广播系统的实现。通过构建实际的聊天应用或实时数据推送系统,帮助开发者掌握 如何使用 Golang 构建高效、可靠的实时通信系统,提高并发处理与系统的可扩展性。

30

2025.12.22

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

142

2026.01.19

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

83

2026.03.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
ECMAScript6 / ES6---十天技能课堂
ECMAScript6 / ES6---十天技能课堂

共25课时 | 2.1万人学习

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

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