ES6 Generator基本使用方法示例


Posted in Javascript onJune 06, 2020

本文实例讲述了ES6 Generator基本使用方法。分享给大家供大家参考,具体如下:

1.Generator介绍

先来一段Generator的基础代码

function* g(){
 yield 100;
 yield 200;
 return 300;
}
let gg = g();
console.log(gg);            // Object [Generator] {}
console.log(gg.next());        // { value: 100, done: false }
console.log(gg.next());        // { value: 200, done: false }
console.log(gg.next());        // { value: 300, done: true }
console.log(gg.next());        // { value: undefined, done: true }

首先我们看到:

  • Generator是由functinon*定义的,在generator内部可以使用yield
  • Generator不是函数,而是一个对象,并且在执行开始就进入暂停状态,而不是直接执行全部操作
  • 通过next()来执行下一步操作,返回的都是{ value: xxx, done: xxx }这样的形式,value代表上一次操作返回的值,done有两个值,一个是true,一个是false,表示整个流程是否全部结束。

2.Generator异步编程

generator是ES6中引入的异步解决方案,我们来看看它与promise处理异步的对比,来看它们的差异。

// 这里模拟了一个异步操作
function asyncFunc(data) {
 return new Promise( resolve => {
  setTimeout(
   function() {
    resolve(data)
   },1000
  )
 })
}

promise的处理方式:

asyncFunc("abc").then( res => {
 console.log(res);                    // "abc"
 return asyncFunc("def")
}).then( res => {
 console.log(res);                    // "def"
 return asyncFunc("ghi")
}).then( res => {
 console.log(res);                    // "ghi"
})

generator的处理方式:

function* g() {
 const r1 = yield asyncFunc("abc");
 console.log(r1);                            // "abc"
 const r2 = yield asyncFunc("def");
 console.log(r2);                            // "def"
 const r3 = yield asyncFunc("ghi");
 console.log(r3);                            // "ghi"
}

let gg = g();
let r1 = gg.next();
r1.value.then(res => {
 let r2 = gg.next(res);
 r2.value.then(res => {
  let r3 = gg.next(res);
  r3.value.then(res => {
   gg.next(res)
  })
 })
})

promise多次回调显得比较复杂,代码也不够简洁,generator在异步处理上看似同步的代码,实际是异步的操作,唯一就是在处理上会相对复杂,如果只进行一次异步操作,generator更合适。

3.yield和yield*

先来看两段代码

function* g1() {
 yield 100;
 yield g2();
 return 400;
}

function* g2() {
 yield 200;
 yield 300;
}

let gg = g1();
console.log(gg.next());                // { value: 100, done: false }
console.log(gg.next());                // { value: Object [Generator] {}, done: false }
console.log(gg.next());                // { value: 400, done: true }
console.log(gg.next());                // { value: undefined, done: true }
function* g1() {
 yield 100;
 yield* g2();
 return 400;
}

function* g2() {
 yield 200;
 yield 300;
}

let gg = g1();
console.log(gg.next());                // { value: 100, done: false }
console.log(gg.next());                // { value: 200, done: false }
console.log(gg.next());                // { value: 300, done: false }
console.log(gg.next());                // { value: 400, done: true }

yield对另一个generator不会进行遍历,返回的是迭代器对象,而yield*会对generator进行遍历迭代。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js版本A*寻路算法
Dec 22 Javascript
图片连续滚动代码[兼容IE/firefox]
Jun 11 Javascript
Javascript生成json的函数代码(可以用php的json_decode解码)
Jun 11 Javascript
jquery解析xml字符串简单示例
Apr 11 Javascript
js实现跨域的4种实用方法原理分析
Oct 29 Javascript
Javascript中的几种继承方式对比分析
Mar 22 Javascript
jquery遍历json对象集合详解
May 18 Javascript
Vue导出页面为PDF格式的实现思路
Jul 31 Javascript
使用vue自定义指令开发表单验证插件validate.js
May 23 Javascript
vue v-for 使用问题整理小结
Aug 04 Javascript
uni-app如何实现增量更新功能
Jan 03 Javascript
浅谈vue 多个变量同时赋相同值互相影响
Aug 05 Javascript
jquery.validate自定义验证用法实例分析【成功提示与择要提示】
Jun 06 #jQuery
ES6 Symbol在对象中的作用实例分析
Jun 06 #Javascript
微信小程序多列表渲染数据开关互不影响的实现
Jun 05 #Javascript
浅谈element中InfiniteScroll按需引入的一点注意事项
Jun 05 #Javascript
使用JavaScript实现网页秒表功能(含开始、暂停、继续、重置功能)
Jun 05 #Javascript
Node.js API详解之 dgram模块用法实例分析
Jun 05 #Javascript
taro 实现购物车逻辑的实例代码
Jun 05 #Javascript
You might like
PHP 金额数字转换成英文
2010/05/06 PHP
深入php list()函数的详解
2013/06/05 PHP
php查询mysql大量数据造成内存不足的解决方法
2015/03/04 PHP
PHP中的流(streams)浅析
2015/07/02 PHP
js cookies实现简单统计访问次数
2009/11/24 Javascript
js 获取radio按钮值的实例
2013/08/17 Javascript
Jquery创建一个层当鼠标移动到层上面不消失效果
2013/12/12 Javascript
基于javascript实现的搜索时自动提示功能
2014/12/26 Javascript
jQuery中scrollLeft()方法用法实例
2015/01/16 Javascript
JS实现带圆弧背景渐变效果的导航菜单代码
2015/10/13 Javascript
jQuery和hwSlider实现内容响应式可触控滑动切换效果附源码下载(二)
2016/06/22 Javascript
js 提交form表单和设置form表单请求路径的实现方法
2016/10/25 Javascript
微信小程序-图片、录音、音频播放、音乐播放、视频、文件代码实例
2016/11/22 Javascript
利用vue写todolist单页应用
2016/12/15 Javascript
谈谈JavaScript中浏览器兼容问题的写法小议
2016/12/17 Javascript
浅谈React碰到v-if
2018/11/04 Javascript
Vue 递归多级菜单的实例代码
2019/05/05 Javascript
Vue分页器实现原理详解
2019/06/28 Javascript
vue中封装axios并实现api接口的统一管理
2020/12/25 Vue.js
[10:14]2018DOTA2国际邀请赛寻真——paiN Gaming不仅为自己而战
2018/08/14 DOTA
详解Python中的测试工具
2019/06/09 Python
Flask使用Pyecharts在单个页面展示多个图表的方法
2019/08/05 Python
Python中 Global和Nonlocal的用法详解
2020/01/20 Python
python json 递归打印所有json子节点信息的例子
2020/02/27 Python
python实现简单的购物程序代码实例
2020/03/03 Python
Python random模块的使用示例
2020/10/10 Python
python关于倒排列的知识点总结
2020/10/13 Python
Django数据模型中on_delete使用详解
2020/11/30 Python
python可视化 matplotlib画图使用colorbar工具自定义颜色
2020/12/07 Python
毕业班联欢会主持词
2014/03/27 职场文书
食品流通安全承诺书
2014/05/22 职场文书
演讲稿的格式及范文
2014/08/22 职场文书
领导班子专题民主生活会情况想汇报
2014/09/30 职场文书
Vue实现tab导航栏并支持左右滑动功能
2021/06/28 Vue.js
浅谈JavaScript浅拷贝和深拷贝
2021/11/07 Javascript
索尼ICF-5900W收音机测评
2022/04/24 无线电