--- 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ón
instanceof
{{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")}}