--- title: Generator slug: Web/JavaScript/Reference/Global_Objects/Generator tags: - ECMAScript 2015 - Generator - JavaScript - Довідка - генератор - застарілий генератор - застарілий ітератор translation_of: Web/JavaScript/Reference/Global_Objects/Generator ---
Об'єкт Generator повертається {{jsxref("Statements/function*", "функцією-генератором", "", 1)}} та відповідає як протоколу ітерабельного об'єкта, так і протоколу ітератора.
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) також реалізував більш ранню версію генераторів у JavaScript 1.7, де зірочка (*) у оголошенні функції не була потрібна (ви просто використовували ключове слово yield у тілі функції). Однак, підтримка застарілих генераторів була прибрана, починаючи з Firefox 58 (вийшов 23 січня, 2018) ({{bug(1083482)}}).
Generator.prototype.next() {{non-standard_inline}}next() у об'єкті-генераторі ES2015.Generator.prototype.close() {{non-standard_inline}}next() викине помилку StopIteration. Цей метод відповідає методу return() у об'єкті-генераторі ES2015.Generator.prototype.send() {{non-standard_inline}}send(x) відповідає методу next(x) у об'єкті-генераторі ES2015.Generator.prototype.throw() {{non-standard_inline}}throw() у об'єкті-генераторі 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()); // викидає StopIteration (бо генератор вже закритий)
| Специфікація | Статус | Коментар |
|---|---|---|
| {{SpecName('ES2015', '#sec-generator-objects', 'Generator objects')}} | {{Spec2('ES2015')}} | Початкове визначення. |
| {{SpecName('ESDraft', '#sec-generator-objects', 'Generator objects')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Generator")}}