Generator - JavaScript 编辑
生成器对象是由一个 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()
- 用于将值发送到生成器。 该值由
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 (ECMA-262) Generator objects | Living Standard |
浏览器兼容性
BCD tables only load in the browser
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.相关链接
Legacy generators
- The legacy generator function
- The legacy generator function expression
StopIteration
- The legacy Iterator protocol
ES2015 generators
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论