Frontend/JavaScript

ES6 제너레이터 함수

findmypiece 2021. 3. 3. 09:43
728x90

redux-saga 에서는 ES6의 제너레이터 함수 문법을 사용한다.

사실 이 문법에 대해 딱히 몰라도 redux-saga를 사용법만 알면 큰 문제가 되지 않지만

원리를 알면 아주 조금은 도움이 된다.

제너레이터 함수는 문자그대로 발전기를 만들어주는 것으로

해당 함수를 최초 호출할 경우 함수 내부 구문이 실행되는 것이 아니라

내부 구문을 실행시킬 수 있는 제너레이터 객체를 리턴하게 된다.

 

이 문법의 핵심기능은 함수를 실행할 때 

함수를 특정구간에 멈춰 놓았다가 다음 호출에 이어서 실행시킬 수 있다는 것이다.

제너레이터 함수는 아래와 같이 정의한다.

function* generatorFunc(){
	console.log('1 구간 진입');
  	let param = yield;

	console.log('1구간에서 입력된 값: ' + param);  
  	console.log('2 구간 진입');
	param = yield;
  
 	console.log('2구간에서 입력된 값: ' + param);  
  	console.log('3 구간 진입');
	param = yield;

	console.log('3구간에서 입력된 값: ' + param);  
  	console.log('제너레이터 종료');
    
	yield '끝';
}

 

사용은 아래와 같이 한다.

const test = generatorFunc();

test.next(111);
// 1 구간 진입
// {value: undefined, done: false}

test.next(222);
// 1구간에서 입력된 값: 222
// 2 구간 진입
// {value: undefined, done: false}

test.next(333);
// 2구간에서 입력된 값: 333
// 3 구간 진입
// {value: undefined, done: false}

test.next(444);
// 3구간에서 입력된 값: 444
// 제너레이터 종료
// {value: "끝", done: false}

test.next(555);
//{value: undefined, done: true}

보면 알겠지만 제너레이터 함수를 정의할때는 function* 를 사용하며

제너레이터 객체 생성후 next 를 호출할 경우 yield가 선언된 행에서

순차적으로 흐름을 멈춘다.

 

제너레이터 함수 안에서는 yield로 next 함수의 인자를 받아올 수 있고

next 함수는 아래와 같은 포맷의 객체리터럴을 고정적으로 리턴한다.

{value: undefined, done: false}

이 때 value 값은 제너레이터 함수에서 yield '111'; 구분으로 지정된 값이며

done는 제너레이터 함수의 종료 여부를 의미한다.

728x90