sitelink1 https://devscb.tistory.com/66 
sitelink2  
sitelink3  
sitelink4  
extra_vars4  
extra_vars5  
extra_vars6  

jQuery(제이쿼리) ajax와 fetch와 Axios 차이점 비교, jquery ajax vs fetch vs axios

 

 

 

Ajax란?

 


전통저인 Ajax는 Asyncronous Javascript and XHTTPREQUEST(XHR)를 가리키며,
http 통신에서의 비동기적으로 데이터를 주고받는 방식의 하나입니다.
데이터가 업데이트 될 때마다 페이지 전체를 받아오는 대신,
화면에서 표시되는 일부 필요한 부분의 데이터에 대해서만 받아와서 업데이트하기 위해 도입되었습니다.
오래전에는 서버에서 데이터를 받아오는데 XML이 사용되었으나, 현재는 기본적으로 json 형식으로 받습니다.
전통적인 ajax의 사용코드는 아래와 같습니다.

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
 if (xhr.readyState === xhr.DONE) {
  if (xhr.status === 200 || xhr.status === 201) {
   console.log(xhr.responseText);
  } else {
   console.error(xhr.responseText);
  }
 }
};
xhr.open('GET', 'http://localhost');
xhr.send();



 

jQuery(제이쿼리) ajax

 


jQuery ajax는 ajax를 쉽게 사용하기 위해 도입된 메소드입니다.
jQuery는 javascript를 좀 더 편리하게 사용하기 위한 라이브러리인데,
그 중 ajax를 편하게 해주는 것이 바로 $.ajax (jquery ajax) 입니다.
전통적인 방식보다 훨씬 더 직관적으로 코드를 작성할 수 있다는 것을 바로 아래코드를 보고 확인할 수 있습니다.
 

$.ajax({
   type: 'POST',
   url: url,
   data: data,
   dataType: dataType,
   success: function (res) { console.log(res); },
   error: function (res) {console.log(res); }
});



 

fetch

 


fetch API는 ES6에서 지원된 비동기 통신을 위한 javascript 내장 api이니다.
모든 모던 브라우저에서 사용이 가능합니다만 아직도 IE(인터넷 익스플로러)를 쓰는 환경이 있다면 사용불가합니다.

 

try {
  let response = await fetch(url);
  let data = response.json();
  console.log(data);
} catch(e) {
  console.log("Oops, error", e);
}



 

axios

 


Axios는 npm에 패키지로 설치하여 사용할 수 있으며, fetch와 동일한 작업을 수행합니다.
다만, fetch와 다르게 IE 11까지도 지원을 합니다.

axios({
    method: 'post',
    url: '/user/12345',
    data: {
        firstName: 'Fred',
        lastName: 'Flintstone'
    }
})
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});




 

jquery ajax vs axios vs fetch 비교 표

 


jquery ajax, axios, fetch 를 비교한 표를 작성해보았습니다.
위에서 소개한 내용 외에도, 아래와 같이 정리할 수 있습니다.

 

 

 

jquery Ajax Axios Fetch
요청객체에 url 존재 요청객체에 url 존재 요청객체에 url 미존재
써드파티 라이브러리 써드파티 라이브러리 모던 웹브라우저에 빌트인된 api, 인스톨 필요하지 않음.
XSRF 보호 지원없음 XSRF 보호 해줌 XSRF 보호 지원없음
parameter로 data property사용 parameter로 data property사용 parameter로 body property사용
Fetch는 string화 되어있음. data는 object를 포함함. Fetch는 string화 되어있음.
반환값에 대해 객체로 사용하기 위해서는 json() 메소드를 사용해야함. 반환값에 대해 자동으로 JSON data로 반환됨. 반환값에 대해 객체로 사용하기 위해서는 json() 메소드를 사용해야함.
timeout 설정방법 존재. timeout 설정방법 존재. timeout 지정방법 존재하지 않음
Axios has built-in support for download progress. Fetch does not support upload progress.

지원브라우저
Chrome: (Current - 1) and Current
Edge: (Current - 1) and Current
Firefox: (Current - 1) and Current, ESR
Internet Explorer: 9+
Safari: (Current - 1) and Current
Opera: Current
지원브라우저
Chrome: Current
Edge: Current
Firefox: Current
Internet Explorer: 11+
Safari: Current
Opera: Current

지원브라우저
Chrome: Current
Edge: Current
Firefox: Current
Internet Explorer: 지원않음
Safari: Current
Opera: Current

 

번호 제목 글쓴이 날짜 조회 수
226 체크박스에 체크된 항목 개수 구하기 황제낙엽 2023.06.10 497
225 JSON 클래스가 지원하는 function 황제낙엽 2023.03.31 224
224 (Copilot) JSON 객체의 내부 데이터 리스트 길이를 구하는 방법 황제낙엽 2023.03.30 249
223 배열에 대한 루프문 조회 (loop iterator) 황제낙엽 2023.03.01 563
222 (Copilot) 바닐라 스크립트가 뭐지? 황제낙엽 2023.02.24 264
221 CryptoJS 를 이용한 암호화 황제낙엽 2023.02.15 472
220 [URLSearchParams] URL 파라미터(매개변수) 값 가져오기 file 황제낙엽 2023.02.02 431
219 Fetch API (CORS 극복을 위한 노력) 황제낙엽 2021.12.05 443
218 두 서버의 자원을 접근하는 클라이언트 프레임웍(Next.js)에서의 CORS오류 file 황제낙엽 2021.12.05 506
217 CORS 의 내용과 이에 대한 우회 방안들 file 황제낙엽 2021.12.05 459
» client 통신 기술 jquery ajax, fetch, axios 황제낙엽 2021.12.05 270
215 문자열에서 역슬래시(backslash) 문자와 유니코드(Unicode)에 대한 고찰 file 황제낙엽 2021.06.03 494
214 XMLHttpRequest Specification 황제낙엽 2021.04.29 428
213 자바스크립트(Javascript) escape, encodeURI, encodeURIComponent 인코딩 함수 황제낙엽 2021.04.27 446
212 자바스크립트 학습용 유튜브 강의 (드림코딩 by 엘리) 황제낙엽 2021.03.07 467
211 IIFE (Immediately Invoked Function Expression) 황제낙엽 2021.03.07 260
210 Arrow function 황제낙엽 2021.03.07 257
209 함수 Call Stack 디버깅을 위한 함수 선언 팁 황제낙엽 2021.03.07 258
208 Function declaration 과 Function expression 의 차이 황제낙엽 2021.03.07 219
207 Early return, early exit - 스크립트 가독성 개선 팁 황제낙엽 2021.03.07 373