当前位置: 首页 > news >正文

ES8——Generator函数的使用

babel工具插件下载:npm i --save babel-polyfill
引入:polyfill.js进行转码(es8->es5)

介绍

  • Generator函数用于生成迭代器
    function * (){}
    • yeild: 作用同return类似
    {const obj = function* () {yield "a";yield 123;};const fn = obj();console.log(fn.next()); // {value: 'a', done: false}console.log(fn.next()); console.log(fn.next()); // {value: undefined, done: true}
    }
    

使用场景

  • 遍历对象属性
{let obj = {name: "jacak",age: 15,phone: 12345678,};obj[Symbol.iterator] = function* () {for (const key of Object.keys(obj)) {yield obj[key];}};for (const val of obj) {console.log(val); // jacak 15 12345678}
}
  • 保持有限个状态
{const status = function* () {while (1) {yield "success";yield "fail";yield "waiting";}};let fn = status();console.log(fn.next());console.log(fn.next());console.log(fn.next());console.log(fn.next());console.log(fn.next());
}

在这里插入图片描述

  • 自动查询支付状态
// 查询支付状态function payState() {return new Promise((res) => {setTimeout(() => {console.log("正在查询...");res({ code: -1 });}, 1000);});}// generator迭代,获取支付状态const getPayState = function* () {yield payState();};function autoQuery() {const it = getPayState();const state = it.next();state.value.then((res) => {if (res.code == 0) {console.log("支付成功");} else {console.log("支付失败...");setTimeout(() => autoQuery(), 500);}});}autoQuery();

在这里插入图片描述

在这里插入图片描述

  • 可以使异步任务按照同步顺序执行
{const ajax = function* () {console.log("任务开始");yield function (fun) {setTimeout(() => {console.log("异步任务执行");fun && fun();}, 2000);};};let fn = ajax();let sn = fn.next();sn.value(() => fn.next());
}
http://www.lryc.cn/news/3775.html

相关文章:

  • 德馨食品冲刺A股上市:计划募资9亿元,林志勇为实际控制人
  • 湿敏电阻的原理,结构,分类与应用总结
  • 千锋教育嵌入式物联网教程之系统编程篇学习-03
  • 升级到https
  • 【C语言】数据结构-二叉树
  • c++中std::condition_variable最全用法归纳
  • Python数据可视化:数据关系图表可视化
  • Urho3D约定
  • python数据结构-列表,元组
  • Properties类读配置文件、修改配置文件
  • 图解LeetCode——剑指 Offer 24. 反转链表
  • 【C语言】“指针的运算”、“指针与数组”
  • Linux高级命令之查找文件命令
  • PyCharm+Docker:打造最舒适的深度学习炼丹炉
  • 【mock】手把手带你用mock写自定义接口+mock常用语法
  • 2023 年腾讯云服务器CVM快速配置购买教程,新手上云必备!
  • opencv显示图像
  • C++:类和对象(中)
  • 53. 最大子数组和
  • 基于Java+SpringBoot+SpringCloud+Vue前后端分离医院管理系统设计与实现
  • QT基础入门【环境配置篇】linux桌面QT开发环境的构建以及问题解决
  • Linux系统之部署企业内部静态导航页
  • 2023备战金三银四,Python自动化软件测试面试宝典合集(四)
  • 算法训练营 day43 动态规划 不同路径 不同路径 II
  • 关联查询的SQL有几种情况
  • 查缺补漏三:事务隔离级别
  • 没有她的通讯录(C语言实现)
  • Spring Security 从入门到精通
  • 微信小程序Springboot vue停车场车位管理系统
  • 看完这篇 教你玩转渗透测试靶机vulnhub——Hack Me Please: 1