yield* - JavaScript 编辑
yield*
表达式用于委托给另一个generator
或可迭代对象。
语法
yield* [[expression]];
expression
- 返回一个可迭代对象的表达式。
描述
yield*
表达式迭代操作数,并产生它返回的每个值。
yield*
表达式本身的值是当迭代器关闭时返回的值(即done
为true
时)。
示例
委托给其他生成器
以下代码中,g1()
yield
出去的每个值都会在 g2()
的 next()
方法中返回,就像那些 yield
语句是写在 g2()
里一样。
function* g1() {
yield 2;
yield 3;
yield 4;
}
function* g2() {
yield 1;
yield* g1();
yield 5;
}
var iterator = g2();
console.log(iterator.next()); // { value: 1, done: false }
console.log(iterator.next()); // { value: 2, done: false }
console.log(iterator.next()); // { value: 3, done: false }
console.log(iterator.next()); // { value: 4, done: false }
console.log(iterator.next()); // { value: 5, done: false }
console.log(iterator.next()); // { value: undefined, done: true }
委托给其他可迭代对象
除了生成器对象这一种可迭代对象,yield*
还可以 yield
其它任意的可迭代对象,比如说数组、字符串、arguments
对象等等。
function* g3() {
yield* [1, 2];
yield* "34";
yield* arguments;
}
var iterator = g3(5, 6);
console.log(iterator.next()); // { value: 1, done: false }
console.log(iterator.next()); // { value: 2, done: false }
console.log(iterator.next()); // { value: "3", done: false }
console.log(iterator.next()); // { value: "4", done: false }
console.log(iterator.next()); // { value: 5, done: false }
console.log(iterator.next()); // { value: 6, done: false }
console.log(iterator.next()); // { value: undefined, done: true }
yield* 表达式的值
yield*
是一个表达式,不是语句,所以它会有自己的值。
function* g4() {
yield* [1, 2, 3];
return "foo";
}
var result;
function* g5() {
result = yield* g4();
}
var iterator = g5();
console.log(iterator.next()); // { value: 1, done: false }
console.log(iterator.next()); // { value: 2, done: false }
console.log(iterator.next()); // { value: 3, done: false }
console.log(iterator.next()); // { value: undefined, done: true },
// 此时 g4() 返回了 { value: "foo", done: true }
console.log(result); // "foo"
规范
Specification | Status | Comment |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) Yield | Standard | Initial definition. |
ECMAScript (ECMA-262) Yield | 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.Firefox 特别提示
- 从 Gecko 33 (Firefox 33 / Thunderbird 33 / SeaMonkey 2.30) 开始,
yield
表达式的解析已被更新以符合ES2015规范(bug 981599):- 现在有行结束符限制。在
yield
和*
之间不允许有换行符。如下代码会抛出SyntaxError
:function* foo() { yield *[]; }
- 现在有行结束符限制。在
相关链接
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论