什么是JavaScript的生成器函数_yield关键字如何控制执行流程?

JavaScript生成器函数用function*声明,通过yield暂停执行并返回迭代器对象;每次调用next()从暂停处继续,yield可传值与接收外部输入,适用于惰性计算、自定义迭代及异步编程基础。

什么是javascript的生成器函数_yield关键字如何控制执行流程?

JavaScript的生成器函数是一种可以暂停和恢复执行的特殊函数,yield 是它的核心控制关键字——它让函数不再“一气呵成”,而是像按了暂停键一样,每次调用 next() 才继续往下走一步。

生成器函数怎么写?

function* 声明,内部用 yield 标记暂停点:

function* count() {  console.log('start');  yield 1;  console.log('after first yield');  yield 2;  console.log('end');  return 'done';}

调用它不会立即执行,而是返回一个**迭代器对象**:

const it = count(); // 没有打印任何内容

yield 怎么控制流程?

每次调用 it.next(),函数从上次暂停处(或开头)运行,直到遇到下一个 yieldreturn

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

it.next() → 输出 'start',返回 { value: 1, done: false }it.next() → 输出 'after first yield',返回 { value: 2, done: false }it.next() → 输出 'end',返回 { value: 'done', done: true }

yield 表达式的值就是 next() 返回的 value;函数结束时 done 变为 true

yield 还能接收外部传入的值

下次调用 next(value) 时传入的参数,会成为上一个 yield 表达式的返回值:

function* echo() {  let input = yield 'ready?';  console.log(input); // 'hello'  yield 'got it';}

使用时:

it.next() → 返回 { value: 'ready?', done: false }it.next('hello')input 得到 'hello',打印并返回 { value: 'got it', done: false }

实际中常用来做什么?

生成器适合需要**分步、惰性、可中断**的场景:

实现自定义迭代逻辑(比如遍历树、分页请求)配合 for...of 自动遍历(只要没 return,done: false 的 yield 都会被取)作为异步编程的早期基础(async/await 就是它的语法糖升级)构造状态机或协程式流程控制

基本上就这些。yield 不是魔法,只是把函数执行权交还给调用方,等你再点“播放”才继续——它让 JS 第一次拥有了真正可控的暂停能力。

以上就是什么是JavaScript的生成器函数_yield关键字如何控制执行流程?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1543972.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 15:30:13
下一篇 2025年12月21日 15:30:31

相关推荐

  • 什么是变量_Javascript中如何声明它们

    JavaScript中变量是存储数据的容器,用let、const、var声明,区别在于作用域和可重赋值性;命名需合法且推荐驼峰式;未声明直接赋值在非严格模式下创建全局变量,严格模式报错。 变量是程序中用来存储数据的“容器”,它的值可以在程序运行过程中被读取、修改或参与运算。在 JavaScript …

    2025年12月21日
    000
  • javascript如何实现插件系统_可扩展架构怎样设计

    JavaScript插件系统核心是主程序预留扩展点、插件按约定注入逻辑,通过标准接口(name/init/destroy/hooks)解耦,由PluginManager统一管理注册、排序与钩子触发,并支持动态加载与沙箱隔离。 插件系统的核心思路 JavaScript 插件系统本质是“主程序预留扩展点…

    2025年12月21日
    000
  • 什么是JavaScript中的严格模式_它如何帮助避免常见错误?

    严格模式通过启用限制性规则提升代码质量与可维护性,需在脚本顶部或函数首行添加”use strict”;激活,能捕获未声明赋值、重复参数等错误,并使this指向更明确。 JavaScript中的严格模式(Strict Mode)是一种让代码在更严格的条件下运行的机制,它通过启用…

    2025年12月21日
    000
  • 什么是javascript符号类型_Symbol的唯一性有什么用处

    Symbol 是 JavaScript 中具有唯一性的原始类型,用于避免属性名冲突、模拟私有成员、实现全局共享键(Symbol.for)及定制内置行为(如 Symbol.iterator)。 Symbol 是 JavaScript 中一种原始数据类型,它的核心特点是“唯一性”——每次调用 Symbo…

    2025年12月21日
    000
  • javascript怎样深度克隆一个对象?_javascript中浅拷贝与深拷贝有何不同?

    深拷贝通过递归复制所有嵌套层级属性实现完全独立,避免引用共享;浅拷贝仅复制第一层,引用类型仍共用内存。推荐优先使用structuredClone(),兼容场景可用JSON序列化或手写递归函数。 JavaScript 中深度克隆对象,核心是**递归复制所有嵌套层级的属性值**,确保新对象与原对象完全独…

    2025年12月21日
    000
  • 什么是javascript事件循环_它怎样管理任务队列?

    JavaScript事件循环通过宏任务和微任务队列实现分时调度,每次执行一个宏任务后立即清空全部微任务,故Promise.then比setTimeout(0)先执行。 JavaScript 事件循环是运行时处理异步操作的核心机制,它让单线程的 JS 能够非阻塞地执行代码。关键不在于“多线程”,而在于…

    2025年12月21日
    000
  • Javascript如何实现继承_ES6类继承和原型继承有何优劣?

    ES6的class继承本质是原型继承的语法糖,更简洁且强制super调用;原型继承更底层灵活但易出错,适用于动态控制或兼容旧环境等特殊场景。 ES6 的 class 继承本质仍是基于原型的继承,只是提供了更简洁、语义更清晰的语法糖;原型继承更底层、灵活,但写法冗长、易出错。选择哪种方式,取决于项目规…

    2025年12月21日
    000
  • javascript闭包是什么_它有什么实际应用价值

    闭包是JavaScript中函数记住并访问其定义时词法作用域变量的机制;由内部函数引用外部局部变量且在外部函数返回后仍被持有而形成,用于模块封装、异步状态保持、函数工厂与柯里化。 闭包是 JavaScript 中一个核心但容易被误解的概念:它指的是一个函数,能够记住并访问其定义时所在词法作用域中的变…

    2025年12月21日
    000
  • Javascript中的TypeScript是什么?

    TypeScript 是 JavaScript 的超集,包含全部 JS 语法并添加静态类型等能力;所有合法 JS 代码都是合法 TS 代码,需编译为 JS 运行,核心价值是提升开发体验与代码安全性。 TypeScript 不是 JavaScript 中的一种东西,它是 JavaScript 的一个超…

    2025年12月21日
    000
  • 如何实现JavaScript数据可视化_Chart.js和D3.js如何选择

    Chart.js适合简单图表、快速上线场景,如后台系统的用户增长曲线和销售占比饼图;D3.js适合高度定制、强交互或数据驱动DOM操作,如关系网络图、地理热力图等。 选Chart.js还是D3.js,关键看需求复杂度和开发资源——简单图表、快速上线,Chart.js更合适;需要高度定制、交互丰富或数…

    2025年12月21日
    000
  • javascript的docker是什么_如何容器化应用?

    JavaScript 的 Docker 是用容器打包运行 Node.js 应用,通过 Dockerfile 构建镜像实现环境一致、启动快、隔离安全、部署标准化;需正确编写 Dockerfile、.dockerignore 和 docker-compose.yml,并执行 build 与 run 命令…

    2025年12月21日 好文分享
    000
  • javascript的事件处理是什么_如何添加事件监听器?

    JavaScript事件处理是通过监听器响应用户操作的机制,核心是用addEventListener绑定函数,支持灵活配置与移除,常用事件包括click、input、submit等。 JavaScript 的事件处理是指让网页对用户的操作(比如点击、输入、滚动等)做出响应的机制。核心就是给元素“绑”…

    2025年12月21日
    000
  • javascript剩余参数是什么_如何用它处理不定数量的参数

    JavaScript剩余参数(…args)允许函数接收任意数量实参并存为真数组,必须位于参数列表末尾;相比arguments类数组,它支持数组方法且适用于箭头函数。 JavaScript 剩余参数(Rest Parameters)是一种语法特性,允许函数接收**任意数量的实参**,并将它…

    2025年12月21日
    000
  • JavaScript中如何操作DOM_getElementById和querySelector

    getElementById只通过ID查找单个元素且不加#号,性能高;querySelector支持CSS选择器(ID需加#),灵活但只返回首个匹配元素;按需选用,ID定位优先用前者,复杂选择用后者。 在JavaScript中,getElementById 和 querySelector 都是用来获…

    2025年12月21日
    000
  • Javascript是什么_它如何让网页动起来?

    JavaScript是运行在浏览器中的编程语言,负责网页的交互行为,通过操作HTML结构和CSS样式实现动态效果,并借助Node.js可拓展至服务端。 JavaScript 是一种运行在浏览器里的编程语言,它让网页从静态文档变成可交互、会响应的动态界面。 JavaScript 能做什么? 它负责网页…

    2025年12月21日
    000
  • JavaScript如何操作摄像头与麦克风?

    JavaScript通过MediaDevices.getUserMedia()获取音视频流,传入{video:true}、{audio:true}或两者组合的约束对象,返回Promise,成功后将MediaStream赋给video.srcObject即可预览,需设autoplay和muted;可独…

    2025年12月21日
    000
  • javascript是什么_如何开始你的第一个编程项目?

    JavaScript是浏览器原生支持的脚本语言,可响应交互、动态更新内容;首行代码console.log(“你好,JavaScript!”)在开发者工具Console中运行;通过HTML文件可实现按钮随机变色等交互功能;学习建议从小功能入手、多实践、以需求驱动,并推荐VS C…

    2025年12月21日
    000
  • javascript XSS攻击是什么_如何防止恶意脚本的注入?

    XSS本质是浏览器执行了攻击者注入的恶意JavaScript代码,分反射型、存储型和DOM型三类;防御需输出编码、避免危险DOM操作、设HttpOnly Cookie及启用CSP。 XSS(跨站脚本攻击)本质是以上就是javascript XSS攻击是什么_如何防止恶意脚本的注入?的详细内容,更多请…

    2025年12月21日
    000
  • javascript事件是什么_如何为网页元素添加点击事件

    JavaScript事件是用户交互触发的信号,addEventListener是现代标准事件监听方法,支持多监听、不覆盖,需确保元素存在DOM中,常用获取方式有getElementById等,避免内联事件和执行时机错误。 JavaScript事件是用户与网页交互时触发的信号,比如点击按钮、输入文字、…

    2025年12月21日
    000
  • Javascript如何操作JSON_如何进行序列化和解析?

    JavaScript操作JSON主要靠JSON.stringify()和JSON.parse():前者将对象序列化为字符串,支持过滤字段和格式化输出;后者将字符串解析为对象,支持reviver函数处理值;二者均不支持函数、undefined、Symbol等类型,需注意Date转换、循环引用及大数字精…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信