深入理解js generator数据类型


Posted in Javascript onAugust 16, 2016

1. 概述

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);

以上这篇深入理解js generator数据类型就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery 操作Javascript对象和数组的工具函数小结
Jan 22 Javascript
基于jQuery的倒计时实现代码
May 30 Javascript
JavaScript中的方法重载实例
Mar 16 Javascript
Javascript实现一个简单的输入关键字添加标签效果实例
Jun 01 Javascript
Easyui ueditor 整合解决不能编辑的问题(推荐)
Jun 25 Javascript
在 Angular 中使用Chart.js 和 ng2-charts的示例代码
Aug 17 Javascript
基于Vue 2.0的模块化前端 UI 组件库小结
Dec 21 Javascript
vue移动端实现红包雨效果
Jun 23 Javascript
vue-cli history模式实现tomcat部署报404的解决方式
Sep 06 Javascript
JavaScript 替换所有匹配内容及正则替换方法
Feb 12 Javascript
原生js实现购物车
Sep 23 Javascript
关于Node.js中频繁修改代码重启服务器的问题
Oct 15 Javascript
js 创建对象 经典模式全面了解
Aug 16 #Javascript
js 上传文件预览的简单实例
Aug 16 #Javascript
js removeChild 方法深入理解
Aug 16 #Javascript
关于javascript中限定时间内防止按钮重复点击的思路详解
Aug 16 #Javascript
总结Node.js中的一些错误类型
Aug 15 #Javascript
自动化测试读写64位操作系统的注册表
Aug 15 #Javascript
Wireshark基本介绍和学习TCP三次握手
Aug 15 #Javascript
You might like
php制作圆形用户头像的实例_自定义封装类源代码
2017/09/18 PHP
ThinkPHP整合datatables实现服务端分页的示例代码
2018/02/10 PHP
PHP进阶学习之反射基本概念与用法分析
2019/06/18 PHP
基于jQuery UI CSS Framework开发Widget的经验
2010/08/21 Javascript
js中巧用cssText属性批量操作样式
2011/03/13 Javascript
JavaScript面向对象知识串结(读JavaScript高级程序设计(第三版))
2012/07/17 Javascript
jquery 跳到顶部和底部动画2句代码简单实现
2013/07/18 Javascript
jquery-syntax动态语法着色示例代码
2014/05/14 Javascript
javascript表单控件实例讲解
2016/09/13 Javascript
js提示框替代系统alert,自动关闭alert对话框的实现方法
2016/11/07 Javascript
让微信小程序支持ES6中Promise特性的方法详解
2017/06/13 Javascript
利用vscode调试编译后的js代码详解
2018/05/14 Javascript
微信小程序实现循环动画效果
2018/07/16 Javascript
bootstrap模态框关闭后清除模态框的数据方法
2018/08/10 Javascript
JavaScript 高性能数组去重的方法
2018/09/20 Javascript
vue动态渲染svg、添加点击事件的实现
2020/03/13 Javascript
selenium 反爬虫之跳过淘宝滑块验证功能的实现代码
2020/08/27 Javascript
vue脚手架项目创建步骤详解
2021/03/02 Vue.js
[01:02:06]LGD vs Mineski Supermajor 胜者组 BO3 第二场 6.5
2018/06/06 DOTA
[48:51]完美世界DOTA2联赛PWL S2 Magma vs InkIce 第一场 11.28
2020/12/02 DOTA
python实现获取Ip归属地等信息
2016/08/27 Python
Python3实现并发检验代理池地址的方法
2016/09/18 Python
python 生成器生成杨辉三角的方法(必看)
2017/04/10 Python
Python文件和流(实例讲解)
2017/09/12 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
Python:Numpy 求平均向量的实例
2019/06/29 Python
Python数据持久化存储实现方法分析
2019/12/21 Python
解决CSS3的opacity属性带来的层叠顺序问题
2016/05/09 HTML / CSS
市场安全管理制度
2014/01/26 职场文书
新浪微博实习心得体会
2014/01/27 职场文书
音乐学专业求职信
2014/07/22 职场文书
2016高一新生军训心得体会
2016/01/11 职场文书
分享几个JavaScript运算符的使用技巧
2021/04/24 Javascript
5种方法告诉你如何使JavaScript 代码库更干净
2021/09/15 Javascript
Linux系统下MySQL配置主从分离的步骤
2022/03/21 MySQL
详解Alibaba Java诊断工具Arthas查看Dubbo动态代理类
2022/04/08 Java/Android