Frontend/React
Promise
취업하고싶다!
2024. 8. 16. 15:07
Promise
비동기 작업의 완료 또는 실패를 나타내는 객체
callback 방식의 call back 지옥을 해결하기 위해 사용
Promise의 3가지 상태
- Pending (대기): 초기 상태로, 이 상태에서는 작업이 아직 완료되지 않음
- Fulfilled (이행): 작업이 성공적으로 완료된 상태로, 결과값이 존재
- Rejected (거부): 작업이 실패한 상태로, 실패 원인(에러)가 존재
Promise의 장점
- 비동기 처리 시점 명확히 표현
- 연속된 비동기 처리 작업 수정, 삭제, 추가 유연
- 비동기 작업 상태 쉽게 확인 가능
- 유지보수 쉬움
후속 처리 메소드
then
- then 메소드는 두 개의 콜백 함수를 인자로 전달받음
- 첫 번째 콜백 함수: 성공(fulfilled, resolve 함수가 호출된 경우)시에 실행
- 두 번째 콜백 함수: (rejected, reject 함수가 호출된 경우)시에 실행
- then 메소드는 기본적으로 프로미스를 반환
const promise = () => new Promise((resolve, reject) => {
let a = 1 + 1
if(a == 3) {
resolve('success')
} else {
reject('failed')
}
})
promise().then((message) => {
console.log('This is in the then ' + message)
}, (error) => {
console.log('This is in the then ' + error)
})
catch
- catch 메소드는 비동기 처리 혹은 then 메소드 실행 중 발생한 에러(예외)가 발생하면 호출
- catch 메소드 역시 프로미스를 반환
const promise = () => new Promise((resolve, reject) => {
let a = 1 + 1
if(a == 3) {
resolve('success')
} else {
reject('failed')
}
})
promise().then((message) => {
console.log('This is in the then ' + message)
}).catch((error) => {
console.log('This is in the catch ' + error)
})
Promise chaining
프로미스의 특징 중 하나로, 프로미스 여러 개를 연결하여 사용할 수 있음
then 메소드를 호출하여 아래와 같이 연결
function getData() {
return new Promise({
// ...});
}
// then() 으로 여러 개의 프로미스를 연결한 형식getData()
getData()
.then(function(data) {
// ...
})
.then(function() {
// ...
})
.then(function() {
// ...
});
Promise.all()
promise.all은 promise가 담겨있는 배열과 같은 이터러블 객체를 인자로 받음
인자로 전달받은 모든 promise를 병렬로 처리하고 그 결과값을 배열에 받아 resolve로 반환함
서로 의존관계이지 않은 여러 프로미스들을 이터러블 객체에 담아 Promise.all 메소드를 이용해 한번에 병렬처리 할 수 있음
가장 마지막으로 끝나는 프로미스를 기준으로 수행되고, 모든 프로미스가 fullfilled 상태가 되면 결과값을 배열에 담아 새로운 프로미스를 반환
Promise.all([
new Promise(resolve => setTimeout(() => resolve(1), 1000)),
new Promise(resolve => setTimeout(() => resolve(2), 2000)),
new Promise(resolve => setTimeout(() => resolve(3), 3000))
]).then(console.log) // 프로그램을 실행하고 3초뒤에 실행됨
.catch(console.log)
[ 1, 2, 3 ]