JavaScript Asynchronous
업데이트:
Promise
- 자바스크립트 비동기 처리에 사용되는 객체이다.
상태
Pending, 대기
- 비동기 처리 로직이 아직 완료되지 않은 상태이다. new Promise() 함수를 호출하면 대기 상태가 된다.
Fulfilled, 이행
- 비동기 처리가 완료되어 프로미스가 결과 값을 반환해준 상태이다. 콜백 함수의 인자 resolve를 실행하면 이행 상태가 된다.
Rejected, 실패
- 비동기 처리가 실패하거나 오류가 발생한 상태이다. 콜백 함수의 인자 reject를 실행하면 실패 상태가 된다.
Promise Chaining, 프로미스 연결
- then() 메서드를 호출하면 새로운 프로미스 객체를 반환하여 다시 then() 메서드를 이어서 사용 가능하다.
new Promise(function(resolve, reject) {
setTimeout(() => resolve(1), 1000);
}).then(function(result) {
alert(result); // 1
return result * 2;
}).then(function(result) {
alert(result); // 2
return result * 2;
}).then(function(result) {
alert(result); // 4
return result * 2;
});
오류 처리
- then()을 사용하여 두 번째 인자로 에러를 처리한다.
- 이 방법으로 호출되면 Uncaught Error가 발생하므로, catch()를 이용하도록 한다.
- catch()를 이용하여 에러를 처리한다.
async, await
- 자바스크립트 비동기 처리 패턴 중 가장 최근에 나온 문법이다.
- 기존 비동기 처리 방식인 콜백 함수와 프로미스의 단점을 보완하고 개발자가 읽기 좋은 코드를 작성 할 수 있도록 해준다.
async function asyncFunction() {
const data = await asyncMethod();
// Logic.
}
async
- 비동기 처리를 하는 함수 앞에 async라는 키워드를 사용한다.
- Ex. async function 함수명() {}
await
- 비동기 처리를 하는 코드 앞에 await라는 키워드를 사용한다.
- Ex. await 함수명()
댓글남기기