자바스크립트 Promise는 비동기 작업을 더욱 효율적으로 처리할 수 있는 방법을 제공합니다. Promise 체이닝은 Promise를 연속적으로 연결하여 비동기 작업의 순서와 처리를 관리하는 기술입니다. 이를 통해 코드 가독성과 유지보수성을 높일 수 있습니다.
Promise란?
Promise는 자바스크립트의 내장 객체로, 비동기 작업이 성공적으로 수행됐는지 또는 실패했는지를 나타내는 것입니다. Promise는 세 가지 상태를 가집니다.
- 대기 중(pending): 작업이 아직 완료되지 않은 상태
- 이행(fulfilled): 작업이 성공적으로 완료된 상태
- 거부(rejected): 작업이 실패한 상태
Promise 객체는 대기 중일 때는 비동기 작업을 수행하고, 이행 또는 거부되면 처리 결과를 반환합니다.
Promise 체이닝
Promise 체이닝은 여러 개의 비동기 작업을 순서대로 처리하는 방법입니다. 각각의 작업은 이전 작업이 완료되면 실행되며, 결과는 다음 작업에 전달됩니다.
다음은 Promise 체이닝의 예시 코드입니다.
asyncFunctionOne()
.then(result1 => {
// 이행 결과 처리
return asyncFunctionTwo(result1);
})
.then(result2 => {
// 이행 결과 처리
return asyncFunctionThree(result2);
})
.then(result3 => {
// 이행 결과 처리
console.log(result3);
})
.catch(error => {
// 거부된 경우 처리
console.error(error);
});
위의 코드에서 asyncFunctionOne
, asyncFunctionTwo
, asyncFunctionThree
는 각각 비동기 작업을 수행하는 함수입니다. 첫 번째 함수가 실행된 후에는 then
메서드를 통해 다음 함수로 결과를 전달하고, 마지막 함수까지 연결된 뒤에는 console.log
를 통해 최종 결과를 출력합니다. 만약 어떤 함수에서 에러가 발생한다면, catch
메서드를 통해 에러를 처리할 수 있습니다.
Promise 체이닝의 장점
Promise 체이닝을 사용하면 비동기 작업을 보다 직관적이고 명확하게 관리할 수 있습니다. 각 작업이 순차적으로 진행되기 때문에 코드가 복잡해지거나 중첩된 콜백 함수를 사용할 필요가 없어집니다. 또한 에러 처리도 편리하게 할 수 있으며, 코드의 가독성과 유지보수성을 향상시킬 수 있습니다.
지속적인 비동기 작업을 다루는 프로젝트에서 Promise 체이닝은 매우 유용한 패턴입니다. 약간의 학습과 연습을 통해 자바스크립트 Promise 체이닝을 더 자유롭게 활용할 수 있을 것입니다.
참고 자료: