Movatterモバイル変換


[0]ホーム

URL:


  1. Web
  2. JavaScript
  3. JavaScript-Referenz
  4. Anweisungen und Deklarationen
  5. function*

Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten.Erfahre mehr über dieses Experiment.

View in EnglishAlways switch to English

function*

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.

Diefunction*-Deklaration erstellt eineBindung einer neuen Generatorfunktion an einen gegebenen Namen. Eine Generatorfunktion kann beendet und später wieder betreten werden, wobei ihr Kontext (variableBindungen) über die Wiedereintrittspunkte hinweg gespeichert wird.

Sie können Generatorfunktionen auch mit demfunction* Ausdruck definieren.

Probieren Sie es aus

function* generator(i) {  yield i;  yield i + 10;}const gen = generator(10);console.log(gen.next().value);// Expected output: 10console.log(gen.next().value);// Expected output: 20

Syntax

js
function* name(param0) {  statements}function* name(param0, param1) {  statements}function* name(param0, param1, /* …, */ paramN) {  statements}

Hinweis:Generatorfunktionen haben keine Pfeilfunktions-Gegenstücke.

Hinweis:function und* sind separate Token, daher können sie durchLeerzeichen oder Zeilenumbrüche getrennt werden.

Parameter

name

Der Funktionsname.

paramOptional

Der Name eines formalen Parameters der Funktion. Für die Syntax der Parameter siehe dieFunktionen Referenz.

statementsOptional

Die Anweisungen, die den Körper der Funktion bilden.

Beschreibung

Einefunction*-Deklaration erstellt einGeneratorFunction-Objekt. Jedes Mal, wenn eine Generatorfunktion aufgerufen wird, gibt sie ein neuesGenerator-Objekt zurück, das demIterator-Protokoll entspricht. Die Ausführung der Generatorfunktion wird bei einem bestimmten Punktsuspendiert, der anfangs am Beginn des Funktionskörpers liegt. Die Generatorfunktion kann mehrfach aufgerufen werden, um mehrere Generatoren gleichzeitig zu erzeugen; jeder Generator behält seinen eigenenAusführungskontext der Generatorfunktion und kann unabhängig betreten werden.

Der Generator erlaubt eine bidirektionale Steuerung des Programmflusses: Der Steuerfluss kann beliebig oft zwischen der Generatorfunktion (Callee) und ihrem Aufrufer übertragen werden, solange beide Parteien dies wünschen. Der Steuerfluss kann vom Aufrufer zum Callee über die Methoden des Generators übertragen werden:next(),throw() undreturn(). Der Steuerfluss kann vom Callee zum Aufrufer übertragen werden, indem die Funktion normal beendet wird, entweder durchreturn,throw, durch Abarbeitung aller Anweisungen, oder durch Nutzung der Ausdrückeyield undyield*.

Wenn die Methodenext() des Generators aufgerufen wird, wird der Körper der Generatorfunktion ausgeführt bis zu einem der folgenden Fälle:

  • Einyield-Ausdruck. In diesem Fall gibt dienext()-Methode ein Objekt mit einervalue-Eigenschaft, die den ausgegebenen Wert enthält, und einerdone-Eigenschaft, die immerfalse ist, zurück. Beim nächsten Aufruf vonnext() ergibt deryield-Ausdruck den Wert, der annext() übergeben wurde.
  • Einyield*, der die Kontrolle an einen anderen Iterator delegiert. In diesem Fall ist dieser Aufruf sowie alle zukünftigennext()-Aufrufe auf den Generator identisch mit Aufrufen vonnext() auf den delegierten Iterator, bis der delegierte Iterator fertig ist.
  • Einereturn-Anweisung (die nicht von einemtry...catch...finally abgefangen wird), oder das Ende des Steuerflusses, was implizitreturn undefined bedeutet. In diesem Fall ist der Generator abgeschlossen, und dienext()-Methode gibt ein Objekt mit einervalue-Eigenschaft, die den zurückgegebenen Wert enthält, und einerdone-Eigenschaft, die immertrue ist, zurück. Weiterenext()-Aufrufe haben keinen Effekt und geben stets{ value: undefined, done: true } zurück.
  • Ein Fehler, der innerhalb der Funktion geworfen wird, entweder durch einethrow-Anweisung oder eine unbehandelte Ausnahme. Dienext()-Methode wirft diesen Fehler und der Generator ist abgeschlossen. Weiterenext()-Aufrufe haben keinen Effekt und geben immer{ value: undefined, done: true } zurück.

Wenn die Methodethrow() des Generators aufgerufen wird, wirkt es so, als ob einethrow-Anweisung an der aktuellen suspendierten Position in den Körper des Generators eingefügt wird. Similarly, when the generator'sreturn() method is called, it acts as if areturn statement is inserted in the generator's body at the current suspended position. Beide Methoden beenden in der Regel den Generator, es sei denn, die Generatorfunktion fängt den Abschluss übertry...catch...finally ab.

Generatoren wurden früher als Paradigma für asynchrone Programmierung verwendet, umCallback Hell zu vermeiden, indemInversion of Control erreicht wurde. Heute wird dieser Anwendungsfall durch das einfachereasync functions-Modell und dasPromise-Objekt gelöst. Dennoch sind Generatoren weiterhin für viele andere Aufgaben nützlich, wie etwa das Definieren vonIteratoren auf eine unkomplizierte Weise.

function*-Deklarationen verhalten sich ähnlich wiefunction-Deklarationen — sie werdengehoistet an den Anfang ihres Geltungsbereichs und können überall in ihrem Geltungsbereich aufgerufen werden, und sie können nur in bestimmten Kontexten neu deklariert werden.

Beispiele

Einfaches Beispiel

js
function* idMaker() {  let index = 0;  while (true) {    yield index++;  }}const gen = idMaker();console.log(gen.next().value); // 0console.log(gen.next().value); // 1console.log(gen.next().value); // 2console.log(gen.next().value); // 3// …

Beispiel mit yield*

js
function* anotherGenerator(i) {  yield i + 1;  yield i + 2;  yield i + 3;}function* generator(i) {  yield i;  yield* anotherGenerator(i);  yield i + 10;}const gen = generator(10);console.log(gen.next().value); // 10console.log(gen.next().value); // 11console.log(gen.next().value); // 12console.log(gen.next().value); // 13console.log(gen.next().value); // 20

Übergabe von Argumenten an Generatoren

js
function* logGenerator() {  console.log(0);  console.log(1, yield);  console.log(2, yield);  console.log(3, yield);}const gen = logGenerator();// the first call of next executes from the start of the function// until the first yield statementgen.next(); // 0gen.next("pretzel"); // 1 pretzelgen.next("california"); // 2 californiagen.next("mayonnaise"); // 3 mayonnaise

Rückgabeanweisung in einem Generator

js
function* yieldAndReturn() {  yield "Y";  return "R";  yield "unreachable";}const gen = yieldAndReturn();console.log(gen.next()); // { value: "Y", done: false }console.log(gen.next()); // { value: "R", done: true }console.log(gen.next()); // { value: undefined, done: true }

Generator als Objekt-Eigenschaft

js
const someObj = {  *generator() {    yield "a";    yield "b";  },};const gen = someObj.generator();console.log(gen.next()); // { value: 'a', done: false }console.log(gen.next()); // { value: 'b', done: false }console.log(gen.next()); // { value: undefined, done: true }

Generator als Objekt-Methode

js
class Foo {  *generator() {    yield 1;    yield 2;    yield 3;  }}const f = new Foo();const gen = f.generator();console.log(gen.next()); // { value: 1, done: false }console.log(gen.next()); // { value: 2, done: false }console.log(gen.next()); // { value: 3, done: false }console.log(gen.next()); // { value: undefined, done: true }

Generator als berechnete Eigenschaft

js
class Foo {  *[Symbol.iterator]() {    yield 1;    yield 2;  }}const SomeObj = {  *[Symbol.iterator]() {    yield "a";    yield "b";  },};console.log(Array.from(new Foo())); // [ 1, 2 ]console.log(Array.from(SomeObj)); // [ 'a', 'b' ]

Generatoren sind nicht konstruierbar

js
function* f() {}const obj = new f(); // throws "TypeError: f is not a constructor

Generatorbeispiel

js
function* powers(n) {  // Endless loop to generate  for (let current = n; ; current *= n) {    yield current;  }}for (const power of powers(2)) {  // Controlling generator  if (power > 32) {    break;  }  console.log(power);  // 2  // 4  // 8  // 16  // 32}

Spezifikationen

Specification
ECMAScript® 2026 Language Specification
# sec-generator-function-definitions

Browser-Kompatibilität

Siehe auch

Help improve MDN

Learn how to contribute Diese Seite wurde automatisch aus dem Englischen übersetzt.

[8]ページ先頭

©2009-2026 Movatter.jp