JS为什么说async/await是generator的语法糖详解


Posted in Javascript onJuly 11, 2019

关于async的介绍,在阮一峰的ES6入门教程中说到:

async 函数是什么?一句话,它就是 Generator 函数的语法糖。

可是,为什么这么说呢?

首先,比如说有一个异步操作,使用 async/await 语法来以同步模拟异步操作。

使用 async/await 实现一个 sleep 的功能

function sleep(time) {
 return new Promise((resolve, reject) => {
 setTimeout(() => {
  resolve(1);
 }, time);
 });
}

async function test () {
 for(let i = 0; i < 10; i++) {
 let result = await sleep(1000);
 console.log(result);
 }
}

将 async/await 转成 generator 和 promise 来实现:

let test = function () {
 // ret 为一个Promise对象,因为ES6语法规定 async 函数的返回值必须是一个 promise 对象
 let ret = _asyncToGenerator(function* () {
 for (let i = 0; i < 10; i++) {
  let result = yield sleep(1000);
  console.log(result);
 }
 });
 return ret;
}();

// generator 自执行器
function _asyncToGenerator(genFn) {
 return new Promise((resolve, reject) => {
 let gen = genFn();
 function step(key, arg) {
  let info = {};
  try {
  info = gen[key](arg);
  } catch (error) {
  reject(error);
  return;
  }
  if (info.done) {
  resolve(info.value);
  } else {
  return Promise.resolve(info.value).then((v) => {
   return step('next', v);
  }, (error) => {
   return step('throw', error);
  });
  }
 }
 step('next');
 });
}

看完以上代码,是不是一目了然了啊。将 async/await 使用 generator 进行改写的关键是要使用 promise 来实现一个 generator 自执行器。在babel中,大体的原理也是类似的。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JavaScript设置IFrame高度自适应(兼容各主流浏览器)
Jun 05 Javascript
JQuery异步加载无限下拉框级联功能实现示例
Feb 19 Javascript
使用jquery实现的循环连续可停顿滚动实例
Nov 23 Javascript
JS模拟实现ECMAScript5新增的数组方法
Mar 20 Javascript
解决html-jquery/js引用外部图片时遇到看不了或出现403的问题
Sep 22 jQuery
详解vue移动端日期选择组件
Feb 22 Javascript
angularjs使用gulp-uglify压缩后执行报错的解决方法
Mar 07 Javascript
Vue组件之极简的地址选择器的实现
May 31 Javascript
vue实现在一个方法执行完后执行另一个方法的示例
Aug 25 Javascript
前后端如何实现登录token拦截校验详解
Sep 03 Javascript
VUE接入腾讯验证码功能(滑块验证)备忘
May 07 Javascript
JS实现的tab切换并显示相应内容模块功能示例
Aug 03 Javascript
Vue 使用计时器实现跑马灯效果的实例代码
Jul 11 #Javascript
Vue 子组件与数据传递问题及注意事项
Jul 11 #Javascript
ES6的异步终极解决方案分享
Jul 11 #Javascript
微信小程序的开发范式BeautyWe.js入门详解
Jul 10 #Javascript
实现一个 Vue 吸顶锚点组件方法
Jul 10 #Javascript
vue webpack重写cookie路径的方法
Jul 10 #Javascript
vue登录页面cookie的使用及页面跳转代码
Jul 10 #Javascript
You might like
php中获得视频时间总长度的另一种方法
2011/09/15 PHP
深入浅析php json 格式控制
2015/12/24 PHP
php字符串比较函数用法小结(strcmp,strcasecmp,strnatcmp及strnatcasecmp)
2016/07/18 PHP
stream.js 一个很小、完全独立的Javascript类库
2011/10/28 Javascript
javascript学习笔记(八) js内置对象
2012/06/19 Javascript
javascript SpiderMonkey中的函数序列化如何进行
2012/12/05 Javascript
js拦截alert对话框另类应用
2013/01/16 Javascript
jquery跟js初始化加载的多种方法及区别介绍
2014/04/02 Javascript
javascript控制在光标位置插入文字适合表情的插入
2014/06/09 Javascript
extjs每个组件要设置唯一的ID否则会出错
2014/06/15 Javascript
JS获取当前网页大小以及屏幕分辨率等
2014/09/05 Javascript
js实现跨域访问的三种方法
2015/12/09 Javascript
jQuery实现鼠标跟随提示层效果代码(可显示文本,Div,Table,Html等)
2016/04/18 Javascript
Bootstrap对话框使用实例讲解
2016/09/24 Javascript
angular实现form验证实例代码
2017/01/17 Javascript
bootstrapValidator 重新启用提交按钮的方法
2017/02/20 Javascript
Angular异步变同步处理方法
2018/08/13 Javascript
详解如何使用微信小程序云函数发送短信验证码
2019/03/13 Javascript
vue插槽slot的简单理解与用法实例分析
2020/03/14 Javascript
如何基于filter实现网站整体变灰功能
2020/04/17 Javascript
[45:18]2018DOTA2亚洲邀请赛 4.3 突围赛 Optic vs iG 第一场
2018/04/04 DOTA
全面了解python中的类,对象,方法,属性
2016/09/11 Python
Python3编程实现获取阿里云ECS实例及监控的方法
2017/08/18 Python
python模拟事件触发机制详解
2018/01/19 Python
Python cookbook(数据结构与算法)找出序列中出现次数最多的元素算法示例
2018/03/15 Python
对python cv2批量灰度图片并保存的实例讲解
2018/11/09 Python
Window系统下Python如何安装OpenCV库
2020/03/05 Python
自定义html标记替换html5新增元素
2008/10/17 HTML / CSS
TripAdvisor台湾:全球最大旅游网站
2018/08/26 全球购物
世嘉游戏英国官方商店:SEGA Shop UK
2019/09/20 全球购物
十佳大学生村官事迹
2014/01/09 职场文书
餐厅考勤管理制度
2014/01/28 职场文书
征用土地赔偿协议书
2014/09/26 职场文书
房产转让协议书(2014版)
2014/09/30 职场文书
银行给客户的感谢信
2015/01/23 职场文书
介绍信范文
2015/01/31 职场文书