生成器对象是由一个 generator function 返回的,并且它符合可迭代协议和迭代器协议。
语法
function* gen() {
yield 1;
yield 2;
yield 3;
}
let g = gen();
// "Generator { }"
方法
Generator.prototype.next()- 返回一个由
yield表达式生成的值。 Generator.prototype.return()- 返回给定的值并结束生成器。
Generator.prototype.throw()- 向生成器抛出一个错误。
示例
一个无限迭代器
function* idMaker(){
let index = 0;
while(true)
yield index++;
}
let gen = idMaker(); // "Generator { }"
console.log(gen.next().value);
// 0
console.log(gen.next().value);
// 1
console.log(gen.next().value);
// 2
// ...
传统的生成器对象
Firefox (SpiderMonkey) 在 JavaScript 1.7 中也实现了一个较早版本的生成器,其中函数声明中的星号(*)不是必需的 (只需在函数体中使用yield 关键字)。但是,旧式生成器已弃用。不要使用它们;他们将被删除 (bug 1083482)。
传统的生成器方法
Generator.prototype.next()- 返回
yield表达式产生的值. 与ES2015 生成器对象的next()方法对应. Generator.prototype.close()- 关闭生成器,因此执行该函数后调用
next()函数时将会抛出StopIteration错误. 与ES2015 生成器对象的return()方法对应.. Generator.prototype.send()- 用于将值发送到生成器Used to send a value to a generator. 该值由
yield表达式返回, 并且返回下一个yield表达式产生的值.send(x)对应于ES2015生成器对象中的next(x) Generator.prototype.throw()- 向生成器抛出错误. 与ES2015 生成器对象的throw()方法对应.
旧生成器对象示例
function fibonacci() {
var a = yield 1;
yield a * 2;
}
var it = fibonacci();
console.log(it); // "Generator { }"
console.log(it.next()); // 1
console.log(it.send(10)); // 20
console.log(it.close()); // undefined
console.log(it.next()); // throws StopIteration (as the generator is now closed)
规范
| Specification | Status | Comment |
|---|---|---|
| ECMAScript 2015 (6th Edition, ECMA-262) Generator objects |
Standard | Initial definition. |
| ECMAScript Latest Draft (ECMA-262) Generator objects |
Draft |
浏览器兼容性
| Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
|---|---|---|---|---|---|
| Basic support | 39.0 | (Yes) | 未实现 | 未实现 | 未实现 |
| Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
|---|---|---|---|---|---|---|
| Basic support | 未实现 | 39.0 | (Yes) | 未实现 | 未实现 | 未实现 |
相关链接
Legacy generators
- The legacy generator function
- The legacy generator function expression
StopIteration- The legacy Iterator protocol