前端 JS 经典:生成器

在 JavaScript 中,**生成器(Generator)**是一种特殊的函数,它可以用来控制迭代器(iterator)的执行,能够暂停和恢复代码的执行。

生成器函数的形式是在普通函数名称之前加一个 *,其主要特征包括:

| function 关键字与函数名之间有一个星号;

| 函数体内部使用关键字 yield 表达式来定义不同的内部状态。

| 生成器函数的使用与普通函数类似,但是调用生成器函数会产生一个迭代器。通过调用迭代器的 next 方法,可以让函数开始或恢复执行。

| yield 关键字可以使生成器函数在执行过程中暂停。在遇到 yield 关键字之前,函数会正常执行,遇到时执行会暂停,函数的作用域状态会被保留下来,直到再次调用 next 方法恢复执行。yield 关键字有点像是函数的中间返回语句,它生成的值会出现在 next 方法返回的对象里。

例如:

javascript 复制代码
function* genFunc() {

  yield "generator";

  yield "hello";

  yield "word";

  return "!";

}



const it = genFunc();

console.log(it.next()); // { done: false, value: 'generator' }

console.log(it.next()); // { donw: false, value: 'hello' }

console.log(it.next()); // { done: false, value: 'word' }

console.log(it.next()); // { done: false, value: '!' }

console.log(it.next()); // { done: true, value: undefined }

执行上述代码,其结果就是迭代器产生的内容。

生成器函数还支持 yield* 表达式,它用于委托(yield delegation),可以将一个生成器的执行委托给另一个生成器,或者用于实现递归操作等。

生成器的特点使得它在处理一些需要逐步生成或处理值的场景中非常有用,例如处理大型数据集、实现异步操作等。它可以让程序在需要的时候才产生下一个值,而不是一次性生成所有的值,从而提高性能和灵活性。

相关推荐
倾颜6 小时前
从 textarea 到 AI 输入框:用 Tiptap 实现 / 命令、@ 引用和结构化请求
前端·langchain·next.js
kyriewen8 小时前
程序员连夜带团队跑路,省了23万:这AI太贵,真的用不起了
前端·javascript·openai
kyriewen8 小时前
你写的代码没有测试,就像出门不锁门——Jest + Testing Library 从入门到不慌
前端·单元测试·jest
yuzhiboyouye9 小时前
web前端英语面试
前端·面试·状态模式
canonical_entropy10 小时前
下一代低代码渲染框架 nop-chaos-flux 的设计原则
前端·低代码·前端框架
东方小月10 小时前
5分钟搞懂Harness Engineering(驾驭工程):从提示词到AI Agent的进化之路
前端·后端·架构
我叫黑大帅10 小时前
为什么需要 @types/react?解决“无法找到模块 react 的声明文件”报错
前端·javascript·面试
之歆11 小时前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong11 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee12 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php