JavaScript에서 'fetch API'는 어떻게 사용하나요?
_____Q1: fetch API란 무엇인가요?
A1: fetch API는 JavaScript에서 네트워크 요청을 보내고 응답을 처리하기 위한 최신 비동기 인터페이스입니다. XMLHttpRequest보다 간결하고 Promise 기반으로 작동하여 비동기 처리를 쉽게 합니다.
Q2: fetch API를 기본적으로 어떻게 사용하나요?
A2: 가장 기본적인 사용법은 다음과 같습니다:
```javascript
fetch('https://api.example.com/data')
.then(response => response.json()) // 응답을 JSON으로 파싱
.then(data => console.log(data)) // 파싱된 데이터 사용
.catch(error => console.error('에러 발생:', error));
```
이 코드는 지정된 URL에 GET 요청을 보내고 응답을 JSON으로 변환하여 출력합니다.
Q3: fetch API로 POST 요청을 보내려면 어떻게 하나요?
A3: POST 요청을 보낼 때는 `fetch` 함수의 두 번째 인자로 옵션 객체를 전달합니다:
```javascript
fetch('https://api.example.com/data', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ name: '홍길동', age: 30 })
})
.then(response => response.json())
.then(data => console.log(data))
.catch(error => console.error('에러 발생:', error));
```
`method`는 HTTP 메서드, `headers`는 요청 헤더, `body`는 서버로 보낼 데이터입니다.
Q4: fetch API에서 응답 상태 코드는 어떻게 확인하나요?
A4: `fetch`의 응답 객체에는 `status` 속성이 있습니다. 다음과 같이 상태를 검사할 수 있습니다:
```javascript
fetch('https://api.example.com/data')
.then(response => {
if (!response.ok) { // status가 200~299 범위인지 확인
throw new Error('네트워크 응답이 정상적이지 않음: ' + response.status);
}
return response.json();
})
.then(data => console.log(data))
.catch(error => console.error('에러 발생:', error));
Q5: fetch로 이미지나 텍스트 등 다른 형식의 응답을 받으려면 어떻게 해야 하나요?
A5: 응답 객체에는 JSON 외에도 다양한 읽기 메서드가 있습니다.
- 텍스트: `response.text()`
- Blob (이미지, 파일): `response.blob()`
- ArrayBuffer (바이너리 데이터): `response.arrayBuffer()`
예:
```javascript
fetch('https://example.com/image.png')
.then(response => response.blob())
.then(imageBlob => {
const imgURL = URL.createObjectURL(imageBlob);
document.querySelector('img').src = imgURL;
});
```
Q6: fetch API는 비동기 함수(async/await)와 함께 사용할 수 있나요?
A6: 네, 가능합니다. 예시:
```javascript
async function getData() {
try {
const response = await fetch('https://api.example.com/data');
if (!response.ok) throw new Error('네트워크 응답 비정상');
const data = await response.json();
console.log(data);
} catch (error) {
console.error('에러 발생:', error);
}
}
getData();
```
Q7: fetch API의 제한 사항은 무엇인가요?
A7:
- CORS 정책에 의해 동일 출처 정책이 적용됩니다.
- HTTP 오류(예: 404, 500)도 Promise가 reject되지 않고 정상적으로 resolve됩니다. 따라서 상태 코드를 직접 수동 검사해야 합니다.
- Internet Explorer에서는 지원하지 않습니다.
---
fetch API는 가독성이 좋고 사용하기 편리한 최신 네트워크 요청 API로, Promise나 async/await와 함께 사용하면 강력한 비동기 처리가 가능합니다.
작성자:
이예린 [비회원]
| 작성일자: 1년 전
2024-09-12 16:03:43
조회수: 160 | 댓글: 0 | 좋아요: 0 | 싫어요: 0
조회수: 160 | 댓글: 0 | 좋아요: 0 | 싫어요: 0
내용이 부정확하다면 싫어요를 클릭해주세요.