[JavaScript] 비동기처리방식 3. async/await

YounGyeom·2021년 5월 23일
0

JavaScript

목록 보기
5/9
post-custom-banner

async/await 란?

promise에서도 then을 지나치게 사용하면 콜백지옥과 같은 문제점이 발생할 수 있다. 이 때에 AsyncAwait을 사용하여 promise를 좀 더 간결하고 간편하게 동기적으로 실행되는것처럼 보이게 만들어 줄 수 있다. 함수 앞에 async를 써주면 코드블록이 자동으로 promise로 바뀐다. 그리고 함수안에서 await을 딜레이가 필요한 부분 앞에 붙여주면 된다. 에러처리도 trycatch를 사용하면 되기때문에 간편하다.

기본문법

async function 함수명(){
    await 비동기처리_메서드명();
}
  1. function 앞에 async를 붙이고
  2. 비동기 작업을 하는 함수에 await을 붙이면 된다.

async

1. 기존 Promise 방식으로 처리할 경우

Promise를 사용하면 반드시 resolvereject를 호출해야 한다.

2. 위 방식을 async 를 사용해서 처리할 경우

async를 사용하면 함수의 코드 블록이 자동으로 Promise로 변환 되어진다.

await

1. 기존 Promise 방식으로 처리할 경우


콜백지옥이 떠오른다.

2. await을 사용하여 수정했을 경우


자바스크립트는 await 를 만나면 프라미스가 처리될 때까지 기다린다. 결과는 그 이후 반환된다. 프라미스가 처리되기를 기다리는 동안에 다른 일(다른 스크립트 실행, 이벤트 처리 등)을 할 수 있기 때문에, CPU 리소스가 낭비되지 않는다.

awaitpromise.then 보다 좀 더 세련되게 프라미스의 result 값을 얻을 수 있도록 해주는 문법이다. promise.then 보다 가독성이 좋고 쓰기도 좋다.

Reference

profile
keep it fresh!
post-custom-banner

0개의 댓글