[JavaScript] 비동기 처리 - Async / Await이란 무엇인가?

2021. 7. 27. 19:42·JavaScript
목차
  1. 비동기 처리의 중요성
  2. Promise의 문제 점
  3. Async / Await
  4. Async / Await 사용 방법
반응형

비동기 처리의 중요성

시간이 걸리는 코드를 비동기 처리하지 않으면 문제가 발생할 수 있음

Ex) 서버에서 Data를 받아와서 출력해야 하는 상황에 비동기 처리를 하지 않으면
Data를 받을때 까지 기다리며 다음 코드들도 기다리게 됨

 

동기, 비동기 차이 예시

 


Promise의 문제 점

체이닝(.then .then .then ...)을 계속하다 보면 코드의 가독성이 떨어짐

Async / Await

비동기 처리방식인 콜백 함수와 프로미스(promise)의 단점을 보완

비동기 처리 패턴 중 가장 최근에 나온 문법

프로미스를 간결하고 동기적으로 실행되는것 처럼 보이게 만들어주는 API

Async를 사용하면 함수의 코드 블록이 자동으로 Promise로 변환 됨

Async / Await 사용 방법

function 앞에 async 키워드

Promise를 리턴하는 모든 비동기 함수 호출부 앞에는 await 키워드
const getApi = async () => {
    const user = await fetch('domain.com/');
    ...
}
try - catch 구문 사용 가능
const getApi = async () => {
    const user = await fetch('domain.com/');
    ...
    try{
    	...
	}
    catch (err) {
    	console.log(err);
    }
}

 

반응형
저작자표시 비영리 변경금지 (새창열림)
  1. 비동기 처리의 중요성
  2. Promise의 문제 점
  3. Async / Await
  4. Async / Await 사용 방법
'JavaScript' 카테고리의 다른 글
  • [JavaScript] Ajax, Axios, fetch 용어 정리 및 장/단점 비교
  • [JavaScript] npm install [패키지 명] --save와 --save -dev의 의미
  • [JavaScript] ...에 대한 Spread 와 Rest
  • [JavaScript] Promise(프로미스) 란 무엇인가?
꾸매코더
꾸매코더
웹 / 앱 개발자
  • 꾸매코더
    꾸매코딩
    꾸매코더
  • 전체
    오늘
    어제
    • 분류 전체보기 (96)
      • JavaScript (18)
        • Deep Dive (0)
      • React (5)
      • React-Native (9)
      • CSS (3)
      • TypeScript (1)
      • CS (10)
      • GitHub (4)
      • Clone Coding (15)
        • Kakaotalk [HTML + CSS] (10)
        • Momentum [JavaScript] (5)
      • Project (30)
        • Timer Project (14)
        • Netflix [React + Hooks] (12)
        • ToDoList [React-Native] (4)
      • 회고 (1)
  • 링크

    • Github
  • hELLO· Designed By정상우.v4.10.3
꾸매코더
[JavaScript] 비동기 처리 - Async / Await이란 무엇인가?

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.