JavaScript中 ES6 generator数据类型详解


Posted in Javascript onAugust 11, 2016

1. generator简介

generator 是ES6引入的新的数据类型, 看上去像一个函数,除了使用return返回, yield可以返回多次。

generator 由function* 定义, (注意*号),

2. 示例

函数无法保存状态, 有时需要全局变量来保存数字;

2.1

'use strict';
function next_id(){
var id = 1;
while(id<100){
yield id;
id++;
}
return id;
}
// 测试:
var
x,
pass = true,
g = next_id();
for (x = 1; x < 100; x ++) {
if (g.next().value !== x) {
pass = false;
alert('测试失败!');
break;
}
}
if (pass) {
alert('测试通过!');
}

2.2 一个无限循环的迭代器

function* idMaker(){
var index = 0;
while(true)
yield index++;
}
var gen = idMaker(); // "Generator { }"
console.log(gen.next().value); // 0
console.log(gen.next().value); // 1
console.log(gen.next().value); // 2

2.3Generator.prototype.next()

当迭代结束时, Generator.next().done ===true, 结束之前 ===false

function* gen() { 
yield 1;
yield 2;
yield 3;
}
var g = gen(); // "Generator { }"
g.next(); // "Object { value: 1, done: false }"
g.next(); // "Object { value: 2, done: false }"
g.next(); // "Object { value: 3, done: false }"
g.next(); // "Object { value: undefined, done: true }"

2.4 Generator.prototype.return();

return方法 返回给定的参数值,并结束迭代器

example

function* gen() { 
yield 1;
yield 2;
yield 3;
}
var g = gen();
g.next(); // { value: 1, done: false }
g.return("foo"); // { value: "foo", done: true }
g.next(); // { value: undefined, done: true }

注意 如果 done的值是true了, 再调用return,返回的值也是undefined

function* gen() {yield 1;}
var g = gen();
console.log(g.next());//{ value: 1, done: false }
console.log(g.next());//{ value: undefined, done: true }
console.log(g.return(1)); //{ value: undefined, done: true }

2.5 Generator.prototype.throw()

thorw()方法, 通过抛出一个异常到迭代器中,来重新获得迭代器的执行;

返回 带有 value和done两个属性的object对象

function* gen() {
while(true) {
try {
yield 42;
} catch(e) {
console.log("Error caught!");
}
}
}
var g = gen();
var a = g.next();
// { value: 42, done: false }
var b = g.throw(new Error("Something went wrong"));
// "Error caught!"
// { value: 42, done: false }
console.log(a);
console.log(b.value+"::"+b.done);

以上所述是小编给大家介绍的JavaScript中 ES6 generator数据类型详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jscript之Open an Excel Spreadsheet
Jun 13 Javascript
asp.net和asp下ACCESS的参数化查询
Jun 11 Javascript
Javascript 对象的解释
Nov 24 Javascript
jQuery插件slider实现拖动滑块选取价格范围
Apr 30 Javascript
c#程序员对TypeScript的认识过程
Jun 19 Javascript
基于Jquery代码实现手风琴菜单
Nov 19 Javascript
JavaScript如何实现跨域请求
Aug 05 Javascript
从零学习node.js之模块规范(一)
Feb 21 Javascript
取消Bootstrap的dropdown-menu点击默认关闭事件方法
Aug 10 Javascript
JS实现获取当前所在周的周六、周日示例分析
May 11 Javascript
JavaScript多种图形实现代码实例
Jun 28 Javascript
vue 解决provide和inject响应的问题
Nov 12 Javascript
基于MVC5和Bootstrap的jQuery TreeView树形控件(二)之数据支持json字符串、list集合
Aug 11 #Javascript
基于MVC5和Bootstrap的jQuery TreeView树形控件(一)之数据支持json字符串、list集合
Aug 11 #Javascript
jQuery的图片轮播插件PgwSlideshow使用详解
Aug 11 #Javascript
jQuery 翻页组件yunm.pager.js实现div局部刷新的思路
Aug 11 #Javascript
jQuery多个版本和其他js库冲突的解决方法
Aug 11 #Javascript
JS获取字符串实际长度(包含汉字)的简单方法
Aug 11 #Javascript
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)
Aug 11 #Javascript
You might like
php缩放gif和png图透明背景变成黑色的解决方法
2014/10/14 PHP
php实现mysql备份恢复分卷处理的方法
2014/12/26 PHP
php实现XSS安全过滤的方法
2015/07/29 PHP
thinkPHP中create方法与令牌验证实例浅析
2015/12/08 PHP
PHP邮箱验证示例教程
2016/06/01 PHP
php入门教程之Zend Studio设置与开发实例
2016/09/09 PHP
PHP封装的PDO数据库操作类实例
2017/06/21 PHP
Ubuntu 16.04中Laravel5.4升级到5.6的步骤
2018/12/07 PHP
实例:用 JavaScript 来操作字符串(一些字符串函数)
2007/02/15 Javascript
读jQuery之三(构建选择器)
2011/06/11 Javascript
jQuery学习笔记 操作jQuery对象 CSS处理
2012/09/19 Javascript
jquery实现手机发送验证码的倒计时代码
2014/02/12 Javascript
iframe的onreadystatechange事件在firefox下的使用
2014/04/16 Javascript
javascript实现全角半角检测的方法
2015/07/23 Javascript
AngularJS单选框及多选框实现双向动态绑定
2016/01/13 Javascript
jquery插件之文字间歇自动向上滚动效果代码
2016/02/25 Javascript
vue页面使用阿里oss上传功能的实例(一)
2017/08/09 Javascript
限时抢购-倒计时的完整实例(分享)
2017/09/17 Javascript
webpack源码之loader机制详解
2018/04/06 Javascript
bootstrap treeview 树形菜单带复选框及级联选择功能
2018/06/08 Javascript
JavaScript实现的简单Tab点击切换功能示例
2018/07/06 Javascript
在vue中使用SockJS实现webSocket通信的过程
2018/08/29 Javascript
vscode下的vue文件格式化问题
2018/11/28 Javascript
VueCli3.0中集成MockApi的方法示例
2019/07/05 Javascript
小程序中this.setData的使用和注意事项
2019/08/28 Javascript
[36:33]Ti4 循环赛第四日 附加赛NEWBEE vs Mouz
2014/07/13 DOTA
详解JavaScript编程中的window与window.screen对象
2015/10/26 Python
Python+django实现文件下载
2016/01/17 Python
利用Python爬取可用的代理IP
2016/08/18 Python
Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
2018/04/30 Python
JupyterNotebook 输出窗口的显示效果调整方法
2020/04/13 Python
广告艺术设计专业自荐书
2014/07/08 职场文书
2014年企业工会工作总结
2014/11/12 职场文书
教师理论学习心得体会
2016/01/21 职场文书
MySql 8.0及对应驱动包匹配的注意点说明
2021/06/23 MySQL
Spring Data JPA框架Repository自定义实现
2022/04/28 Java/Android