js中yield和yield*表达式的介绍
本篇文章给大家分享《js中yield和yield*表达式的介绍》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
yield用于暂停生成器函数并返回单个值,调用next()继续执行;yield*委托给其他生成器或可迭代对象,逐个产出其值。

在JavaScript中,yield 和 yield* 是用于生成器函数(Generator Functions)的关键字。它们让函数可以暂停执行、返回中间值,并在之后恢复执行,是实现惰性求值和控制流程的重要工具。
yield 表达式
yield 只能在用 function* 定义的生成器函数内部使用。它会暂停函数的执行,并向调用者返回一个值。当调用生成器的 next() 方法时,函数才会继续执行。
基本语法:
function* myGenerator() {yield '第一步';
yield '第二步';
return '结束';
}
使用示例:
const gen = myGenerator();console.log(gen.next()); // { value: '第一步', done: false }
console.log(gen.next()); // { value: '第二步', done: false }
console.log(gen.next()); // { value: '结束', done: true }
每次调用 next(),函数从上次暂停的地方继续执行,直到遇到下一个 yield 或函数结束。
yield* 表达式
yield* 用于委托给另一个生成器或可迭代对象(如数组、字符串、Map等)。它会“展开”被委托的迭代器,逐个产出其中的值。
常见用法包括:
- 组合多个生成器函数
- 遍历嵌套结构
- 复用已有生成逻辑
示例:
function* generatorA() {yield 'a';
yield 'b';
}
function* generatorB() {
yield* generatorA();
yield 'c';
}
for (const val of generatorB()) {
console.log(val); // 输出 a, b, c
}
也可以 yield* 普通可迭代对象:
function* gen() {yield* [1, 2, 3];
}
console.log([...gen()]); // [1, 2, 3]
yield 与 yield* 的区别
关键差异在于处理对象的方式:
- yield:返回右侧表达式的值作为当前产出结果
- yield*:遍历右侧的可迭代对象或生成器,把每个元素依次 yield 出去
比如 yield [1,2,3] 返回整个数组,而 yield* [1,2,3] 会分别产出 1、2、3。
基本上就这些。掌握 yield 和 yield* 能帮助你写出更灵活的数据流处理逻辑,尤其是在需要延迟计算或构建复杂迭代流程时特别有用。注意它们只能在生成器函数中使用,否则会报错。
今天关于《js中yield和yield*表达式的介绍》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
Golang如何优化网络数据传输效率_Golang网络传输性能提升实践
- 上一篇
- Golang如何优化网络数据传输效率_Golang网络传输性能提升实践
- 下一篇
- 3步AI总结会议录音,重点不遗漏
-
- 文章 · 前端 | 2天前 | js语法教程
- JSSet集合使用与去重技巧详解
- 350浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTML5离线缓存清除方法大全
- 462浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTML编码如何避免乱码问题
- 235浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTMLaddress标签使用方法详解
- 309浏览 收藏
-
- 文章 · 前端 | 2天前 |
- 发布订阅模式消息队列原理与实现解析
- 135浏览 收藏

