yield
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.
Der yield
Operator wird verwendet, um eine Generatorfunktion anzuhalten und wieder aufzunehmen.
Probieren Sie es aus
function* foo(index) {
while (index < 2) {
yield index;
index++;
}
}
const iterator = foo(0);
console.log(iterator.next().value);
// Expected output: 0
console.log(iterator.next().value);
// Expected output: 1
Syntax
yield
yield expression
Parameter
expression
Optional-
Der Wert, der von der Generatorfunktion über das Iterator-Protokoll ausgegeben wird. Falls weggelassen, wird
undefined
ausgegeben.
Rückgabewert
Gibt den optionalen Wert zurück, der durch die next()
-Methode des Generators übergeben wurde, um dessen Ausführung fortzusetzen.
Hinweis:
Das bedeutet, dass next()
asymmetrisch ist: Es sendet immer einen Wert an das aktuell angehaltene yield
, gibt aber den Operanden des nächsten yield
zurück. Das Argument, das dem ersten Aufruf von next()
übergeben wird, kann nicht abgerufen werden, da kein aktuell angehaltenes yield
vorhanden ist.
Beschreibung
Das Schlüsselwort yield
pausiert die Ausführung der Generatorfunktion, und der Wert des Ausdrucks nach dem Schlüsselwort yield
wird an den Aufrufer des Generators zurückgegeben. Es kann als generatorbasierte Version des Schlüsselworts return
betrachtet werden.
yield
kann nur direkt innerhalb der Generatorfunktion verwendet werden, die es enthält. Es kann nicht innerhalb verschachtelter Funktionen verwendet werden.
Der Aufruf einer Generatorfunktion erstellt ein Generator
-Objekt. Jedes Mal, wenn die next()
-Methode des Generators aufgerufen wird, wird die Ausführung des Generators fortgesetzt, und er läuft weiter, bis er auf einen der folgenden Punkte stößt:
- Einen
yield
-Ausdruck. In diesem Fall pausiert der Generator, und dienext()
-Methode gibt ein Iterator-Resultat zurück, ein Objekt mit zwei Eigenschaften:value
unddone
. Die Eigenschaftvalue
ist der Wert des Ausdrucks nach demyield
-Operator, unddone
istfalse
, was darauf hinweist, dass die Generatorfunktion noch nicht vollständig abgeschlossen ist. - Das Ende der Generatorfunktion. In diesem Fall beendet sich die Ausführung des Generators, und die
next()
-Methode gibt ein Iterator-Resultat zurück, bei demvalue
undefined
ist unddone
true
ist. - Eine
return
-Anweisung. In diesem Fall wird die Ausführung des Generators beendet, und dienext()
-Methode gibt ein Iterator-Resultat zurück, bei demvalue
der angegebene Rückgabewert ist unddone
true
ist. - Eine
throw
-Anweisung. In diesem Fall wird die Ausführung des Generators vollständig abgebrochen, und dienext()
-Methode löst die angegebene Ausnahme aus.
Einmal bei einem yield
-Ausdruck pausiert, bleibt die Code-Ausführung des Generators angehalten, bis die next()
-Methode des Generators erneut aufgerufen wird. Wenn ein optionaler Wert an die next()
-Methode des Generators übergeben wird, wird dieser Wert zu dem Wert, der von der aktuellen yield
-Operation des Generators zurückgegeben wird. Der erste next()
-Aufruf hat keine entsprechende angehaltene yield
-Operation, sodass es keine Möglichkeit gibt, das Argument des ersten next()
-Aufrufs zu erhalten.
Wenn die return()
- oder throw()
-Methode des Generators aufgerufen wird, verhält es sich so, als ob eine return
- oder throw
-Anweisung an dem angehaltenen yield
-Ausdruck ausgeführt wurde. Sie können try...catch...finally
innerhalb des Generatorfunktionkörpers verwenden, um solche vorzeitigen Beendigungen zu handhaben. Wenn die return()
- oder throw()
-Methode aufgerufen wird, aber kein angehaltener yield
-Ausdruck vorhanden ist (weil next()
noch nicht aufgerufen wurde oder weil der Generator bereits abgeschlossen ist), können die vorzeitigen Beendigungen nicht behandelt werden und führen immer zum Abbruch des Generators.
Beispiele
Verwendung von yield
Der folgende Code ist die Deklaration einer Beispiel-Generatorfunktion.
function* countAppleSales() {
const saleList = [3, 7, 5];
for (let i = 0; i < saleList.length; i++) {
yield saleList[i];
}
}
Sobald eine Generatorfunktion definiert ist, kann sie durch die Erstellung eines Iterators wie gezeigt verwendet werden.
const appleStore = countAppleSales(); // Generator { }
console.log(appleStore.next()); // { value: 3, done: false }
console.log(appleStore.next()); // { value: 7, done: false }
console.log(appleStore.next()); // { value: 5, done: false }
console.log(appleStore.next()); // { value: undefined, done: true }
Es ist auch möglich, einen Wert mit next(value)
in den Generator zu senden. step
wird als Rückgabewert des yield
-Ausdrucks ausgewertet — obwohl der Wert, der an die next()
-Methode des Generators beim ersten Aufruf von next()
übergeben wird, ignoriert wird.
function* counter(value) {
while (true) {
const step = yield value++;
if (step) {
value += step;
}
}
}
const generatorFunc = counter(0);
console.log(generatorFunc.next().value); // 0
console.log(generatorFunc.next().value); // 1
console.log(generatorFunc.next().value); // 2
console.log(generatorFunc.next().value); // 3
console.log(generatorFunc.next(10).value); // 14
console.log(generatorFunc.next().value); // 15
console.log(generatorFunc.next(10).value); // 26
Spezifikationen
Specification |
---|
ECMAScript® 2025 Language Specification # prod-YieldExpression |
Browser-Kompatibilität
BCD tables only load in the browser