--- title: yield* slug: Web/JavaScript/Reference/Operators/yield* tags: - ECMAScript 2015 - Generators - Iterable - Iterator - JavaScript - Operador - Operator - Reference - Referencia translation_of: Web/JavaScript/Reference/Operators/yield* ---
A expressão yield*
é usada para delegar para outro objeto {{jsxref("Statements/function*", "generator")}} ou iterable.
yield* [[expressão]];
expressão
A expressão yield*
itera sobre a operação e yields cada valor retornado por ele.
O valor da expressão yield*
sozinha é o valor retornado pelo iterator quando ele for fechado (i.e., quando done
é true
).
No código seguinte, valores "yeldados" por g1()
são retornados por next()
chamam apenas os que foram "yeldados" por 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}
Além de objetos generator, yield*
também podem yield
outros tipos de objetos iterables, e.g. arrays, strings ou objetos de argumentos.
function* g3() { yield* [1, 2]; yield* '34'; yield* Array.from(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*
sozinhayield*
é uma expressão, não uma declaração, então ele espera um valor.
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() returned {value: 'foo', done: true} nesse ponto console.log(result); // "foo"
Especificação | Situação | Comentário |
---|---|---|
{{SpecName('ES2015', '#', 'Yield')}} | {{Spec2('ES2015')}} | Definição inicial. |
{{SpecName('ESDraft', '#', 'Yield')}} | {{Spec2('ESDraft')}} |
{{CompatibilityTable}}
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|---|
Basic support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop("27.0")}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatSafari("10")}} |
Feature | Android | Edge | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatGeckoMobile("27.0")}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatSafari("10")}} |
function* foo() { yield *[]; }