45장 프로미스

Yuzu·2023년 7월 7일
0

비동기 처리를 위한 패턴
1. 콜백 함수 : 콜백 헬로 인해 가독성이 안좋음, 여러 개의 비동기 처리를 한 번에 처리하는데 한계가 있음
2. 프로미스(Promise) : 비동기 처리 시점을 명확하게 표현할 수 있음

45.1 비동기 처리를 위한 콜백 패턴의 단점

1. 콜백 헬

비동기 함수: 함수 내부에 비동기로 동작하는 코드를 포함한 함수
비동기 함수를 호출하면 함수 내부의 비동기로 동작하는 코드가 오나료되지 않았다 해도 기다리지 않고 즉시 종료된다.
= 비동기 함수 내부의 비동기로 동작하는 코드는 비동기 함수가 종료된 이후에 완료된다.

콜백 헬(callback hell) : 콜백 함수를 통해 비동기 처리 결과에 대한 후속 처리를 수행하는 비동기 함수가 비동기 처리 결과를 가지고 또다시 비동기 함수를 호출해야 한다면 콜백 함수 호출이 중첩되어 복잡도가 높아지는 현상

45.2 프로미스의 생성

  • Promise 생성자 함수를 new 연산자와 함께 호출
  • 비동기 처리를 수행할 콜백 함수를 인수로 전달받고, 이 콜백 함수는 resolve와 reject 함수를 인수로 전달받는다.
 // 프로미스 생성
const promise = new Promise((resolve, reject) => {
        if (// 비동기 처리 성공){
        resolve('result');
        } else { // 비동기 처리 실패
        reject('failure reason');
     	}
    });

비동기 처리 성공 : resolve 함수를 호출해 프로미스를 fulfilled 상태로 변경한다.
비동기 처리 실패 : reject 함수를 호출해 프로미스를 rejected 상태로 변경한다.

  • 비동기 처리가 성공하면 프로미스는 pending 상태에서 fulfilled 상태로 변화한다. 그리고 비동기 처리 결과인 1을 값으로 갖는다.
  • 비동기 처리가 실패하면 프로미스는 pending 상태에서 rejected 상태로 변화한다. 그리고 비동기 처리 결과인 Error 객체를 값으로 갖는다.
  • 프로미스는 비동기 처리 상태와 처리 결과를 관리하는 객체다.

45.3 프로미스의 후속 처리 메서드

프로미스의 비동기 처리 상태가 변화하면 후속 처리 메서드에 인수로 전달한 콜백 함수가 선택적으로 호출된다.

  • 모든 후속 처리 메서드는 프로미스를 반환하며, 비동기로 동작한다.

1. Promise.prototype.then

then 메서드는 두 개의 콜백 함수를 인수로 전달받는다.

  • 첫 번째 콜백 함수는 프로미스가 fulfilled 상태(resolve 함수가 호출된 상태)가 되면 호출된다.
  • 두 번째 콜백 함수는 프로미스가 rejected 상태(reject 함수가 호출된 상태)가 되면 호출된다. 이때 콜백 함수는 프로미스의 에러를 인수로 전달받는다.

2. Promise.prototype.catch

  • 한 개의 콜백 함수를 인수로 전달받는다.
  • 프로미스가 rejected 상태인 경우만 호출된다.
  • catch 메서드는 then 과 동일하게 동작하여 언제나 promise를 반환한다.

3. Promise.prototype.finally

  • 한 개의 콜백 함수를 인수로 전달받는다.
  • finally 메서드의 콜백 함수는 프로미스의 성공 또는 실패와 상관없이 무조건 한 번 호출된다.
  • 언제나 promise를 반환한다.

4. 프로미스의 에러 처리

5. 프로미스 체이닝

6. 프로미스의 정적 메서드

Promise의 5가지 정적 메서드

1. Promise.resolve / Promise.reject

2. Promise.all

여러 개의 비동기 처리를 모두 병렬(parallel) 처리할 때 사용한다.

3. Promise.race

프로미스를 요소로 갖는 배열 등의 이터러블을 인수로 전달받는다.

4. Promise.allSettled

45.8 fetch

HTTP 요청 전송 기능을 제공하는 클라이언트 사이드 Web API

fetch 함수에는 HTTP 요청을 전송할 URL과 HTTP 요청 메서드, HTTP 요청 헤더, 페이로드 등을 설정한 객체를 전달한다.

  • fetch 함수는 HTTP 응답을 나타내는 Response 객체를 래핑한 Promise 객체를 반환한다.
  • Response 객체는 HTTP 응답을 나타내는 다양한 프로퍼티를 제공한다.
  • axios는 모든 HTTP 에러를 reject하는 프로미스를 반환한다.
profile
냐하

0개의 댓글