--- title: Generator.prototype.throw() slug: Web/JavaScript/Reference/Global_Objects/Generator/throw translation_of: Web/JavaScript/Reference/Global_Objects/Generator/throw original_slug: Web/JavaScript/Referencia/Objetos_globales/Generador/throw ---
El método throw() reanuda la ejecución de un generador al lanzar un error en éste y regresar un objeto con las dos propiedades done y value.
gen.throw(excepción)
excepcióninstanceof {{jsxref("Error")}}.Un {{jsxref("Object")}} con dos propiedades:
done (booleano)
verdadero si el iterador ya llegó al final de la secuencia. En este caso valor define opcionalmente el valor de retorno del iterador.falso si el iterador puede dar un siguiente valor en la secuencia. Es equivalente a no definir la propiedad done.value - cualquier valor Javascript regresado por el iterador. Éste puede ser omitido si done is verdadero.throw()The following example shows a simple generator and an error that is thrown using the throw method. An error can be caught by a try...catch block as usual.
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 }
| Specification | Status | Comment |
|---|---|---|
| {{SpecName('ES2015', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} | {{Spec2('ES2015')}} | Initial definition. |
| {{SpecName('ESDraft', '#sec-generator.prototype.throw', 'Generator.prototype.throw')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Generator.throw")}}