--- title: Generator slug: Web/JavaScript/Reference/Global_Objects/Generator tags: - ECMAScript 2015 - Generator - JavaScript - Довідка - генератор - застарілий генератор - застарілий ітератор translation_of: Web/JavaScript/Reference/Global_Objects/Generator ---
{{JSRef}}

Об'єкт Generator повертається {{jsxref("Statements/function*", "функцією-генератором", "", 1)}} та відповідає як протоколу ітерабельного об'єкта, так і протоколу ітератора.

Синтаксис

function* gen() {
  yield 1;
  yield 2;
  yield 3;
}

var g = gen(); // "Generator { }"

Методи

{{jsxref("Generator.prototype.next()")}}
Повертає значення, видане виразом {{jsxref("Operators/yield", "yield")}}.
{{jsxref("Generator.prototype.return()")}}
Повертає надане значення та завершує генератор.
{{jsxref("Generator.prototype.throw()")}}
Викидає помилку у генераторі (також завершує генератор, якщо помилка не була перехоплена всередині генератора).

Приклад

Нескінченний ітератор

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}}
Повертає значення, видане виразом {{jsxref("Operators/yield", "yield")}}. Цей метод відповідає методу next() у об'єкті-генераторі ES2015.
Generator.prototype.close() {{non-standard_inline}}
Закриває генератор, таким чином, виклик next() викине помилку StopIteration. Цей метод відповідає методу return() у об'єкті-генераторі ES2015.
Generator.prototype.send() {{non-standard_inline}}
Відсилав значення у генератор. Значення повертається виразом {{jsxref("Operators/yield", "yield")}} та повертає значення, видане наступним виразом {{jsxref("Operators/yield", "yield")}}. Метод 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")}}

Див. також

Застарілі генератори

Генератори ES2015