> 웹 프론트엔드 > JS 튜토리얼 > JavaScript의 생성기 기능이란 무엇입니까? 그리고 어떻게 작동하나요?

JavaScript의 생성기 기능이란 무엇입니까? 그리고 어떻게 작동하나요?

Linda Hamilton
풀어 주다: 2024-12-31 18:47:11
원래의
500명이 탐색했습니다.

What is generator function in JavaScript? and How does it work?

JavaScript의 생성기 함수는 실행 중에 일시 중지하고 다시 시작할 수 있는 특별한 유형의 함수입니다. function* 구문을 사용하여 정의되며 Yield 키워드를 사용하여 순차적으로 값을 생성합니다.

제너레이터 기능의 주요 특징

  1. 함수로 정의*:
function* generatorFunction(){
  yield 1;
  yield 2;
  yield 3;
  yield 4; 
}
로그인 후 복사

2.반복자를 반환합니다

  • 생성기 함수가 호출되면 즉시 실행되지 않습니다. 대신 반복자 객체를 반환합니다.
  • 반복자에는 다음을 제어하는 ​​데 사용되는 next() 메서드가 있습니다. 실행.
    1. 수확량 키워드:
  • yield 키워드는 값을 생성하고 생성기를 일시 중지하는 데 사용됩니다.
  • next()가 다시 호출되면 생성기는 다음에서 실행을 재개합니다. 일시정지된 지점입니다.

생성기 기능의 예:

function* generatorFunction(){
   console.log("start");
   yield 1;
   console.log("Resume");
   yield 2; 
   console.log("End");

}
const gen = generatorFuntion();
console.log(gen.next());
console.log(gen.next());
console.log(gen.next());
로그인 후 복사

산출

start 
{value: 1, done: false}
Resume
{value: 2, done: false}
End
{Value: undefined, done: true}
로그인 후 복사

작동 방식

  1. next() 실행:
    • next()가 처음 호출되면 생성기가 시작됩니다. 실행하고 첫 번째 산출물까지 실행됩니다.
    • 다음과 같이 {value, done} 객체를 반환합니다.
      • value: Yield로 생산되는 가치.
      • done: 생성기가 완료되었는지 여부를 나타내는 부울
  2. 일시 중지 및 재개.
    • yield를 만나면 함수 실행을 일시 중지합니다.
    • next()가 다시 호출되면 일시정지된 부분부터 재개됩니다.
  3. 완료:
    • 생성기 함수가 완료되면 done 속성은 다음과 같습니다. 맞습니다.

위 내용은 JavaScript의 생성기 기능이란 무엇입니까? 그리고 어떻게 작동하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿