June.

11월 안에는 꼭...

Portfolio

About

fetch와 axios의 차이점

2023/01/06
짧.

2 min read

fetch와 axios의 차이점

Locales:

en

ko

Axios

Axios는 기본적으로 XMLHttpRequest 객체를 사용해서 서버와 통신을 한다. fetch에서는 되지만 XHR(XMLHttpRequest)에서는 안되는 것들이 있다.

fetch에서는 되지만 axios(xhr)에서는 안되는 것들

Progress Report

fetch method를 사용하면 다운로드가 어느정도 진행이 됐는지 알 수 있다.

  • fetch progress

Cache API

요청이나 응답에 대해서 메모리에 오래 남도록 캐싱할 수 있다.

Policy Control

Cross Origin Resource Sharing이나 위에서 나왔던 Cache를 컨트롤 할 수 있다.

Stream

fetch는 stream을 지원하지만, XHR은 응답 전체를 메모리에 버퍼링한다.

Abort Controller

fetch는 요청을 중단할 수 있는 객체인 Abort Controller를 제공한다.

API 호환성과 번들 사이즈 차이

fetch는 자체적으로 API(Promise 기반 인터페이스, AbortController 등등)들이 구현되어있지만, axios(XHR)은 fetch에서 기본적으로 제공해주는 기능들을 구현해야 하기 때문에 번들 사이즈가 무거워지는 경향이 있다.

axios는 29kb 정도의 번들 사이즈를 가지고 있다.
axios는 29kb 정도의 번들 사이즈를 가지고 있다.

그 대체재로 redaxios 라이브러리가 있는데 fetch 기반으로 구현이 되어있고, axios 최소한으로 호환되게 만들어놨다. (fetch 기반 axios API minimal compat)

redaxios는 2kb 정도의 번들 사이즈를 가지고 있다.
redaxios는 2kb 정도의 번들 사이즈를 가지고 있다.

Node.js 18버전부터 지원 가능

원래 fetch는 웹 API에 속해있었기 때문에 웹이 아닌 단순 런타임 환경에서 자바스크립트를 이용하기 위한 Node.js 환경에서는 fetch를 사용할 수 없었다. 하지만 Node.js 18버전으로 업데이트 되면서 fetch를 사용할 수 있게 되었다.

node 18버전에서 fetch가 추가되었다.
node 18버전에서 fetch가 추가되었다.

그래서 node 환경에서 fetch를 사용하기 위한 node-fetch 라이브러리나 isomorphic-fetch 라이브러리가 없이도 Browser, Node.js, Bun, Cloudflare Worker 환경에서 fetch를 사용할 수 있게 되었다.

라이브러리를 사용하기전에 자신의 프로젝트에서 필요한 것들을 잘 생각하고 선택을 하자.

관련 포스트가 4개 있어요.

useSyncExternalStore가 무엇일까?

짧.
react-use-sync-external-store cover image
2023/10/23 (updated)

React 18 useSyncExternalStore에 대해서

CSS flex box의 align-items의 flex-start와 baseline의 차이점에 대해서

짧.
css-flex-box-align-items-attributes cover image
2023/09/24

CSS에서 align-items의 flex-start와 baseline의 차이점

React 18.0.0 react-dom의 flushSync의 사용법과 주의사항에 대해서 알아보자.

짧.
react-flush-sync cover image
2023/09/24

React flushSync에 대해서

maxLength를 넣고 이모지를 넣으면 브라우저마다 계산되는 것이 다르다.

짧.
html-input-max-length cover image
2023/09/15

HTML `<input />`의 maxLength 동작이 safari에서 다른 이슈

profile

정현수.

Currently Managed

Currently not managed

© 2024. junghyeonsu all rights reserved.