Ajax 요청 내에서 한번 더 비동기 작업하기

2024. 5. 24. 16:59· JavaScript/Modern JavaScript

Ajax로 API 요청을 사용할 때, 종종 서버로부터 암호화된 데이터를 받아 이를 비동기적으로 복호화해야 하는 경우가 있는데 이때 success에서 처리하면 실행되지 않는 경우가 발생하곤 합니다.

 

아래는 기본 Ajax 요청입니다.

$.ajax({
    url: '/path/to/api',
    dataType: 'json',
    success: function (data) {
        console.log("Data received:", data);
    },
    error: function (jqXHR, textStatus, errorThrown) {
        console.error("Ajax request failed:", textStatus, errorThrown);
    }
});

 

이때 다음과 같은 비동기 작업(암호화 등)이 success에 들어가야 할 경우

async function decryptData(encryptedData) {
    // 암호화된 데이터를 복호화하는 가상의 함수
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            // 복호화된 데이터 반환
            resolve(JSON.parse(atob(encryptedData)));
        }, 1000);
    });
}

 

아래와 같이 success에 즉시 실행되는 비동기 함수로 만들어 넣으면 됩니다.

$.ajax({
    url: '/path/to/api',
    dataType: 'json',
    success: function (encryptedJson) {
        (async function() {
            try {
                let json = await decryptData(encryptedJson);
                console.log("Decrypted JSON:", json);
                // 복호화된 데이터를 사용하여 DOM을 업데이트하는 등의 작업 수행
            } catch (error) {
                console.error("Decryption or processing error:", error);
            }
        })();
    },
    error: function (jqXHR, textStatus, errorThrown) {
        console.error("Ajax request failed:", textStatus, errorThrown);
        console.error("Response text:", jqXHR.responseText);
    }
});

즉 아래 코드처럼 비동기 작업을 하면 됩니다.

(async function() { ... })();
반응형

'JavaScript > Modern JavaScript' 카테고리의 다른 글

[JavaScript] 원시 타입이란  (0) 2021.06.22
[JavaScript] 변수 메커니즘 2  (0) 2021.06.08
[JavaScript] 변수 메커니즘  (0) 2021.06.07
'JavaScript/Modern JavaScript' 카테고리의 다른 글
  • [JavaScript] 원시 타입이란
  • [JavaScript] 변수 메커니즘 2
  • [JavaScript] 변수 메커니즘
DSeung
DSeung
DSeung
Dev log
DSeung
  • 분류 전체보기 (192)
    • PHP (62)
      • Laravel (31)
      • Error (5)
      • Setting (11)
      • Modern PHP (15)
    • Go Lang (51)
      • Study (30)
      • Algorithm (17)
      • Setting (1)
      • Error (3)
    • Java (11)
      • Spring (3)
      • JSP (0)
      • Error (2)
      • Setting (2)
      • 단축키 (2)
    • JavaScript (6)
      • Modern JavaScript (4)
      • Node (1)
    • Android Kotlin (5)
      • Study (4)
      • Error (1)
    • 컴퓨팅 기술 (12)
      • 데이터베이스시스템 (4)
      • Docker (2)
      • 크롤링 & 스크래핑 (1)
      • API (1)
      • 클라우드 (1)
      • 네트워크 (1)
    • MySQL (7)
    • AWS (1)
    • Git (5)
      • GItLab (1)
      • GitHub (4)
    • 도메인 (2)
      • 안과 (2)
    • 자격증 (7)
      • SQLD (1)
      • 정보처리기사 (6)
    • Mac os (1)
    • 나머지 (13)
      • tistory (1)
      • 기타 (9)
      • 일기 (3)
    • 독서 (9)

인기 글

최근 글

블로그 메뉴

  • 홈
  • 태그
전체
오늘
어제
hELLO · Designed By 정상우.v4.2.0
DSeung
Ajax 요청 내에서 한번 더 비동기 작업하기
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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