Generator
The Generator
object is returned by a generator function and it conforms to both the iterable protocol and the iterator protocol.
Constructor
This object cannot be instantiated directly. Instead, a Generator
instance can be returned from a generator function:
function* generator() { yield 1; yield 2; yield 3; } const gen = generator(); // "Generator { }" console.log(gen.next().value); // 1 console.log(gen.next().value); // 2 console.log(gen.next().value); // 3
Instance methods
Generator.prototype.next()
-
Returns a value yielded by the
yield
expression. Generator.prototype.return()
-
Returns the given value and finishes the generator.
Generator.prototype.throw()
-
Throws an error to a generator (also finishes the generator, unless caught from within that generator).
Examples
An infinite iterator
With a generator function, values are not evaluated until they are needed. Therefore a generator allows us to define a potentially infinite data structure.
function* infinite() { let index = 0; while (true) { yield index++; } } const generator = infinite(); // "Generator { }" console.log(generator.next().value); // 0 console.log(generator.next().value); // 1 console.log(generator.next().value); // 2 // ...
Specifications
Browser compatibility
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
Generator |
39 |
13 |
26 |
No |
26 |
10 |
39 |
39 |
26 |
26 |
10 |
4.0 |
next |
39 |
13 |
26 |
No |
26 |
10 |
39 |
39 |
26 |
26 |
10 |
4.0 |
return |
50 |
13 |
38 |
No |
37 |
10 |
50 |
50 |
38 |
37 |
10 |
5.0 |
throw |
39 |
13 |
26 |
No |
26 |
10 |
39 |
39 |
26 |
26 |
10 |
4.0 |
See also
© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Generator