Generator.prototype.next()
next()
메서드는 done
과 value
속성을 가지는 객체를 반환 합니다. next
메서드에 매개변수를 제공하여 값을 제너레이터로 보낼 수도 있습니다.
구문
js
generatorObject.next(value);
매개변수
value
-
제너레이터로 보낼 값입니다.
값은
yield
식의 결과로 할당됩니다. 예를 들어variable = yield 식
에서.next()
함수에 전달된 값은variable
에 할당됩니다.
반환 값
예제
next() 사용하기
다음 예제에서는 간단한 제너레이터와 next
메서드가 반환하는 객체를 보여 줍니다.
js
function* gen() {
yield 1;
yield 2;
yield 3;
}
const g = gen(); // "Generator { }"
g.next(); // "Object { value: 1, done: false }"
g.next(); // "Object { value: 2, done: false }"
g.next(); // "Object { value: 3, done: false }"
g.next(); // "Object { value: undefined, done: true }"
리스트와 함께 next() 사용하기
이 예제에서 getPage
는 리스트를 받아 pageSize
크기의 청크로 "페이지 나누기"를 수행합니다. next
를 호출할 때마다 그러한 청크가 하나 생성됩니다.
js
function* getPage(pageSize = 1, list) {
let output = [];
let index = 0;
while (index < list.length) {
output = [];
for (let i = index; i < index + pageSize; i++) {
if (list[i]) {
output.push(list[i]);
}
}
yield output;
index += pageSize;
}
}
list = [1, 2, 3, 4, 5, 6, 7, 8];
let page = getPage(3, list); // Generator { }
page.next(); // Object {value: (3) [1, 2, 3], done: false}
page.next(); // Object {value: (3) [4, 5, 6], done: false}
page.next(); // Object {value: (2) [7, 8], done: false}
page.next(); // Object {value: undefined, done: true}
제너레이터에 값 보내기
이 예제에서는 값과 함께 next
를 호출합니다.
참고: 제너레이터가 처음에는 아무것도 생성하지 않았기 때문에 첫 번째 호출에서 기록되는 것은 없습니다.
js
function* gen() {
while (true) {
let value = yield null;
console.log(value);
}
}
const g = gen();
g.next(1);
// "{ value: null, done: false }"
g.next(2);
// 2
// "{ value: null, done: false }"
명세서
Specification |
---|
ECMAScript Language Specification # sec-generator.prototype.next |
브라우저 호환성
BCD tables only load in the browser