--- title: Generator.prototype.throw() slug: Web/JavaScript/Reference/Global_Objects/Generator/throw tags: - ECMAScript 2015 - Generator - JavaScript - Method - Prototype - Reference translation_of: Web/JavaScript/Reference/Global_Objects/Generator/throw ---
Die throw()
Methode übergibt dem Generator eine Exception, welche im Generator zu einem Fehler führt. Zudem wird ein Objekt mit den zwei Eigenschaften done
und value
zurückgegeben.
gen.throw(exception)
exception
Ein Objekt
mit zwei Eigenschaften:
done
(boolean)
true
, wenn der Iterator am Ende der Sequenz angekommen ist. In diesem Fall ist value
, der Rückgabewert des Iterators, optional spezifiziert.false
, wenn der Iterator einen weiteren Wert aus der Sequenz produzieren kann. Das ist gleichbedeutend damit, dass die done
Eigenschaft nicht spezifiziert ist.value
- Ein JavaScript Wert, der von einem Iterator zurückgegeben wird. Kann weggelassen werden, wenn done
true
ist.throw()
Das folgende Beispiel zeigt einen einfachen Generator und einen Fehler der mit der throw
Methode erzeugt wird. Ein Fehler kann mit try...catch
abgefangen werden.
function* gen() { while(true) { try { yield 42; } catch(e) { console.log('Error caught!'); } } } var g = gen(); g.next(); // { value: 42, done: false } g.throw(new Error('Something went wrong')); // "Error caught!" // { value: 42, done: false }
Spezifikation | Status | Kommentar |
---|---|---|
{{SpecName('ES2015', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} | {{Spec2('ES2015')}} | Initiale Definition. |
{{SpecName('ESDraft', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Generator.throw")}}