--- title: Generator slug: Web/JavaScript/Reference/Global_Objects/Generator tags: - ECMAScript 2015 - Generator - JavaScript - Reference translation_of: Web/JavaScript/Reference/Global_Objects/Generator original_slug: Web/JavaScript/Reference/Objets_globaux/Generator ---
L'objet Generator
est renvoyé par une {{jsxref("Instructions/function*","fonction génératrice","",1)}}, c'est à la fois un itérateur et un itérable.
function* gen() { yield 1; yield 2; yield 3; } var g = gen(); // "Generator { }"
function* idMaker(){ var index = 0; while(true) yield index++; } var gen = idMaker(); // "Generator { }" console.log(gen.next().value); // 0 console.log(gen.next().value); // 1 console.log(gen.next().value); // 2 // ...
Firefox (SpiderMonkey) implémente également une version antérieure pour les générateurs avec JavaScript 1.7. Pour cette syntaxe, il n'y a pas besoin d'utiliser l'astérisque dans la déclaration de la fonction, il suffit d'utiliser le mot-clé yield
dans le corps de la fonction. Les générateurs historiques sont une fonctionnalité dépréciée et seront supprimés à l'avenir ({{bug(1083482)}}), il est fortement déconseillé de les utiliser.
Generator.prototype.next()
{{non-standard_inline}}next()
pour les générateurs ES2015.Generator.prototype.close()
{{non-standard_inline}}next()
renverra une exception {{jsxref("StopIteration")}}. Cela correspond à la méthode return()
pour les générateurs ES2015.Generator.prototype.send()
{{non-standard_inline}}send(x)
correspond à next(x)
pour les générateurs ES2015.Generator.
prototype.
throw()
{{non-standard_inline}}throw()
pour les générateurs ES2015.function* fibonacci() { var a = yield 1; yield a * 2; } var it = fibonacci(); console.log(it); // "Generator { }" console.log(it.next()); // 1 console.log(it.send(10)); // 20 console.log(it.close()); // undefined console.log(it.next()); // throws StopIteration (le générateur est clôturé)
Spécification | État | Commentaires |
---|---|---|
{{SpecName('ES2015', '#sec-generator-objects', 'Generator objects')}} | {{Spec2('ES2015')}} | Définition initiale. |
{{SpecName('ESDraft', '#sec-generator-objects', 'Generator objects')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Generator")}}