개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.05.28 13:19

Promise.allSettled(promises) 사용 시 오류 처리 방법

목록
  • 반응형디자인매니아 5일 전 2025.05.28 13:19
  • 21
    1
선생님, Promise.allSettled(promises) 함수를 사용하여 여러 개의 Promise를 처리할 때, 오류가 발생한 Promise는 어떻게 처리되나요?

예를 들어, 다음과 같은 코드가 있습니다.

javascript

const promises = [

  Promise.resolve('성공 1'),

  Promise.reject('에러 1'),

  Promise.resolve('성공 2'),

  Promise.reject('에러 2')

];



Promise.allSettled(promises).then((results) => {

  console.log(results);

});



이 코드를 실행하면, 결과는 다음과 같습니다.

javascript

[

  { status: 'fulfilled', value: '성공 1' },

  { status: 'rejected', reason: '에러 1' },

  { status: 'fulfilled', value: '성공 2' },

  { status: 'rejected', reason: '에러 2' }

]



오류가 발생한 Promise('에러 1'와 '에러 2')는 어떻게 처리되나요? 오류를 처리하는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  5일 전



    Promise.allSettled(promises) 함수는 모든 Promise가 settled 상태가 될 때까지 기다립니다. settled 상태란 fulfilled 또는 rejected 상태를 의미합니다. 이 함수는 오류가 발생한 Promise를 처리하는 방법을 제공하지 않습니다. 오류를 처리하려면 catch 블록을 사용하여 오류를 캐치해야 합니다.

    다음은 예제와 함께 오류를 처리하는 방법을 설명합니다.

    #hostingforum.kr
    javascript
    
    const promises = [
    
      Promise.resolve('성공 1'),
    
      Promise.reject('에러 1'),
    
      Promise.resolve('성공 2'),
    
      Promise.reject('에러 2')
    
    ];
    
    
    
    Promise.allSettled(promises)
    
      .then((results) => {
    
        console.log(results);
    
      })
    
      .catch((error) => {
    
        console.error('오류:', error);
    
      });
    
    


    위 코드에서 catch 블록은 오류를 캐치하여 처리합니다. 오류가 발생한 Promise의 reason을 console.error에 출력합니다.

    또 다른 방법은 Promise.allSettled(promises) 함수를 사용하여 오류를 처리하는 방법을 설명합니다.

    #hostingforum.kr
    javascript
    
    const promises = [
    
      Promise.resolve('성공 1'),
    
      Promise.reject('에러 1'),
    
      Promise.resolve('성공 2'),
    
      Promise.reject('에러 2')
    
    ];
    
    
    
    Promise.allSettled(promises)
    
      .then((results) => {
    
        results.forEach((result) => {
    
          if (result.status === 'rejected') {
    
            console.error(`오류: ${result.reason}`);
    
          } else {
    
            console.log(`성공: ${result.value}`);
    
          }
    
        });
    
      });
    
    


    위 코드에서 results.forEach() 메소드를 사용하여 각 Promise의 상태를 확인합니다. rejected 상태인 경우 오류를 console.error에 출력하고, fulfilled 상태인 경우 성공을 console.log에 출력합니다.

    2025-05-28 13:20

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 24,670건 / 14 페이지

검색

게시물 검색