반응형
250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- html5기초
- 웹디자인예제
- NFT솔라나
- PostgresSQL
- html5예제
- HTML5
- grpc
- html5포트폴리오예제
- 솔라나
- html5기초예제
- 웹예제
- solanaNFT
- 서버
- html5배경만들기
- 솔라나cookbook
- 포트폴리오
- NFT
- html5글자효과
- html5디자인예제
- NFT개발
- 포트폴리오예제
- html5popup
- nft예제
- pgpool
- 웹디자인
- 솔라나개발
- html5웹디자인예제
- 이중화
- 솔라나NFT
- html5웹디자인
Archives
- Today
- Total
Scikit Web
017 - 비동기 통신 Ajax Callback 지옥 피하기 본문
728x90
반응형
프론트 엔드 영역을 개발하다보면 ajax를 많이 사용하게 됩니다. 요즘은 fetch 라는 것도 나와서 fetch도 많이 사용하는 추세 입니다.
ajax를 쓰던 fetch를 쓰던 .. 1번 ajax 안에 2번 ajax, 2번 ajax 안에 3번 ajax 를 써서 문자 그대로 Callback 지옥을 만들게 됩니다.
이런 Callback 사용은 좋은 프로그래밍이 아니며 나중에 유지보수 할때도 난이도를 어렵게 만드는 요소가 됩니다.
이런 상황을 피하고자 나온 방법들이 Promise 와 Asyc await 입니다. 2개는 각각 다른 기능이지만 아래와 같은 상황에서 콜백 지옥을 피하기 위해서 두 기능을 같이 사용하여 풀어낼수 있습니다.
$( document ).ready(async function() {
const callPromise = function(paramUrl) {
return new Promise((resolve, reject) => {
$.ajax({
type: "GET",
url: paramUrl,
success: function (respData, textStatus, jqXHR) {
resolve(respData);
},
error: function (xhr, status, error) {
reject(error);
}
});
});
}
const response = await callPromise('TEST API');
console.log(response);
});
728x90
반응형
'웹디자인 고급 > jQuery' 카테고리의 다른 글
jQuery Ajax GET 비동기 통신 기본 예제 (0) | 2022.06.11 |
---|
Comments