Esta página ha sido traducida del inglés por la comunidad.Aprende más y únete a la comunidad de MDN Web Docs.
Generador
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since septiembre de 2016.
El objetoGenerator es retornado por unafunción generator y es conformado tanto el protocolo iterable como el protocolo iterador.
In this article
Constructor
Este objeto no puede ser instanciado directamente. En su lugar, una instancia del objetoGenerator puede ser devuelta por unafunción generator:
function* gen() { yield 1; yield 2; yield 3;}var g = gen(); // "Generator { }"Métodos de instanciación
Tambien hereda propiedades deIterator.
Generator.prototype.next()Retorna el valor ofrecido por la expresión
yieldGenerator.prototype.return()Retorna el valor dado y finaliza el generador.
Generator.prototype.throw()Lanza un error al generador (también finaliza el generador, a menos que sea atrapado desde ese generador)
Propiedades
Tambien hereda propiedades deIterator.
Generator.prototype.constructorEspecifica la funciòn que construye el prototipo del objeto.
Generator.prototype[@@toStringTag]La cadena
"Generator".
Ejemplo
>Un iterador infinito
function* idMaker() { var index = 0; while (true) yield index++;}var gen = idMaker(); // "Generator { }"console.log(gen.next().value); // 0console.log(gen.next().value); // 1console.log(gen.next().value); // 2// ...Objetos generadores legados
Firefox(SpiderMonkey) tambén implementa una versión mas temprana de generadores en JavaScript 1.7, donde el asterisco (*) en la declaración de la funcion no era necesario(sólo use la palabra reservada yield en el cuerpo de la función). Sin embargo, los generadores legados se encuentran depreciados. No los use. Serán removidos (Error 1083482 en Firefox).
Métodos de generadores legados
Generator.prototype.next()No estándarRetorna el valor ofrecido por la expresión
yield. Esto se corresponde con el método next() en el objeto generador de ES2015.Generator.prototype.close()No estándarCierra el generador. Sí el método next() es llamado por la expresión
StopIteration, un error será lanzado. Esto se corresponde con el método return() del objeto generador de ES2015.Generator.prototype.send()No estándarUtilizado para enviar un valor al generador. El valor es retornado por la expresion
yield, y retorna el valor ofrecido por la siguiente expresionyield.send(x)Se corresponde anext(x)en el objeto generador de ECMAScript 2015.Generator.prototype.throw()No estándarLanza un error al generador. Esto se corresponde con el metodo throw() en el objeto genererador de ES2015.
Ejemplo de generador legado
function fibonacci() { var a = yield 1; yield a * 2;}var it = fibonacci();console.log(it); // "Generator { }"console.log(it.next()); // 1console.log(it.send(10)); // 20console.log(it.close()); // undefinedconsole.log(it.next()); // throws StopIteration (as the generator is now closed)Especificaciones
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-generator-objects> |