웹프로그래밍/ES6

[ES6] Async and Await

ssung.k 2020. 1. 3. 04:38

이번 포스팅에서는 asyncawait 에 대해서 알아보도록 하겠습니다.

이를 제대로 이해하기 위해서는 저번 포스팅을 먼저 이해해야 합니다.

https://ssungkang.tistory.com/entry/ES6-Promises-then-catch-all-race-finally

 

[ES6] Promises - then, catch, all, race, finally

이번 포스팅에서는 js 의 Promises 에 대해서 알아보도록 하겠습니다. javascript 의 비동기성 사람은 한 번에 두 가지 일을 할 수가 없습니다. 흔히들 말하는 멀티태스킹도 실제로는 한 번에 두 가지 일을 동시에..

ssungkang.tistory.com

왜냐면 이들을 Promise 의 업데이트한 것이기 때문입니다.

업데이트를 한 이유는 간단합니다.

기존에는 복잡해질수록 then 을 여러 번 사용해주어야하고 가독성을 해칠 우려가 있었습니다.

때문에 보다 좋은 코드를 위해서 등장한 것이죠.

 

Async and Await

우선 저번 시간에 사용했던 코드입니다.

영화 목록 API 를 통해 목록을 조회하는데 response.json() 을 통해 바로 데이터에 접근할려고 하자 내부에 Promise 가 또 존재해서 then 을 한 번 더 사용해주었습니다.

그 결과 성공적으로 데이터를 가져올 수 있었죠.

const movieListPromise = () => {
  fetch("https://yts.lt/api/v2/list_movies.json")
    .then(response => response.json())
    .then(json => console.log(json))
};

 

이를 asyncawait 를 통해 구현해봅시다.

우선 async 의 사용 방법은 아래와 같습니다.

// 일반 함수
async function myFunc(){

}

// arrow 함수
myFunc = async() => {
  
}

 

다음으로 await 는 항상 async 로 정의된 함수 내에서만 사용이 가능합니다.

이는 then 과 유사한 역할로 promise 가 끝나기를 기다려줍니다.

await 를 사용하기 전에는 pending 에 막혔습니다.

movieListAsync = async() => {
  const response = fetch("https://yts.lt/api/v2/list_movies.json");
  console.log(response);
}

movieListAsync();
// Promise {<pending>}

 

await 를 사용하자 promise 가 끝나기를 기다려 원하는 결과값을 얻을 수 있었습니다.

movieListAsync = async() => {
  const response = await fetch("https://yts.lt/api/v2/list_movies.json");
  console.log(response);
}

movieListAsync();
// Response {type: "cors", url: "https://yts.lt/api/v2/list_movies.json", redirected: false, status: 200, ok: true, …}

 

위에서 then 을 두 번 사용했듯이 이번에는 await 를 두 번 사용하여 promisethen 을 사용한 코드와 같은 결과를 얻을 수 있도록 해보겠습니다.

movieListAsync = async () => {
  const response = await fetch("https://yts.lt/api/v2/list_movies.json");
  console.log(response);
  const json = await response.json();
  console.log(json);
}

 

Try and Catch, Finally

await 를 통해 then 을 대체해보았습니다.

이번에는 async 방식으로 catch 를 대체해보도록 하겠습니다.

이를 대체하는 것은 trycatch 입니다.

python 을 해보셨다면 이미 익숙하실 겁니다.

 

실행할 코드들을 try 로 감싸주고 그 뒤에 catch 는 에러메세지를 인자로 받습니다.

try 내부라면 어디서 에러가 일어나도 catch 가 이를 전부 처리합니다.

movieListAsync = async () => {
  try {
    const response = await fetch("https://yts.lt/api/v2/list_movies.json");
    const json = await response.json();
    console.log(json);
  } catch(e){
    console.log(e);
  }
};

 

finally 를 사용하는 것 역시 위와 비슷하고 아주 간단합니다.

catch 뒤에 비슷한 방식으로 위치해주면 됩니다.

movieListAsync = async () => {
  try {
    const response = await fetch("https://yts.lt/api/v2/list_movies.json");
    const json = await response.json();
    console.log(json);
  } catch(e){
    console.log(e);
  } finally {
    console.log("finally");
  }
};

 

Parallel

지금까지 배운 내용들을 토대로 Parallel 하게 두 API 에 접근해야 한다고 생각해봅시다.

all 을 통해서 fetch 두 개를 받고 다시 all 을 한 번 더 사용하여 json 형식으로 바꿔줍니다.

나머지 부분에 대해서는 위와 동일합니다.

movieListAsync = async () => {
  try {
    const [moviesResponse, suggestionsResponse] = await Promise.all([
      fetch("https://yts.lt/api/v2/list_movies.json"),
      fetch("https://yts.lt/api/v2/movie_suggestions.json?movie_id=100")
    ]);

    const [movies, suggestions] = await Promise.all([moviesResponse.json(), suggestionsResponse.json()]);
    
    console.log(movies, suggestions);
  } catch(e){
    console.log(e);
  } finally {
    console.log("finally");
  }
};