상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 자바스크립트에서 XMLHttpRequest 객체의 사용법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
`XMLHttpRequest` 객체는 JavaScript에서 서버와 비동기적으로 데이터를 주고받기 위해 사용되는 API입니다. 이 객체는 웹 페이지가 서버와 통신할 수 있도록 해주며, AJAX(Asynchronous JavaScript and XML) 기술의 핵심 요소 중 하나입니다. `XMLHttpRequest`를 사용하면 페이지를 새로 고치지 않고도 서버로부터 데이터를 받아오거나 서버에 데이터를 전송할 수 있습니다. 기본 사용법 1. 객체 생성 : `XMLHttpRequest` 객체를 생성합니다. ```javascript var xhr = new XMLHttpRequest(); ``` 2. 요청 초기화 : `open` 메서드를 사용하여 요청을 초기화합니다. 이 메서드는 HTTP 메서드(GET, POST 등), 요청할 URL, 비동기 여부를 인자로 받습니다. ```javascript xhr.open('GET', 'https://api.example.com/data', true); ``` 3. 헤더 설정 (선택적) : 필요에 따라 요청 헤더를 설정할 수 있습니다. 예를 들어, JSON 데이터를 전송할 때는 `Content-Type`을 설정합니다. ```javascript xhr.setRequestHeader('Content-Type', 'application/json'); ``` 4. <a href='https://sangseek.com/sangseeks/응답/ko'>응답</a> 처리 : `onreadystatechange` 이벤트 핸들러를 설정하여 요청의 상태가 변경될 때마다 호출되는 함수를 정의합니다. `readyState` 속성은 요청의 현재 상태를 나타내며, `status` 속성은 HTTP 응답 상태 코드를 나타냅니다. ```javascript xhr.onreadystatechange = function() { if (xhr.readyState === 4) { // 요청이 완료되었을 때 if (xhr.status === 200) { // 성공적으로 응답을 받았을 때 console.log(xhr.responseText); // 서버의 응답 데이터 } else { console.error('Error: ' + xhr.status); // 오류 처리 } } }; ``` 5. 요청 전송 : `send` 메서드를 호출하여 요청을 서버로 전송합니다. POST 요청의 경우 데이터도 함께 전송할 수 있습니다. ```javascript xhr.send(); // GET 요청 // 또는 xhr.send(JSON.stringify({ key: 'value' })); // POST 요청 ``` 예제 다음은 `XMLHttpRequest`를 사용하여 JSON 데이터를 GET 요청으로 가져오는 간단한 예제입니다. ```javascript var xhr = new XMLHttpRequest(); xhr.open('GET', 'https://api.example.com/data', true); xhr.onreadystatechange = function() { if (xhr.readyState === 4) { if (xhr.status === 200) { var data = JSON.parse(xhr.responseText); console.log(data); } else { console.error('Error: ' + xhr.status); } } }; xhr.send(); ``` POST 요청 예제 다음은 `XMLHttpRequest`를 사용하여 JSON 데이터를 POST 요청으로 전송하는 예제입니다. ```javascript var xhr = new XMLHttpRequest(); xhr.open('POST', 'https://api.example.com/data', true); xhr.setRequestHeader('Content-Type', 'application/json'); xhr.onreadystatechange = function() { if (xhr.readyState === 4) { if (xhr.status === 201) { console.log('Data successfully sent'); } else { console.error('Error: ' + xhr.status); } } }; var data = JSON.stringify({ key: 'value' }); xhr.send(data); ``` 주의사항 - CORS : 다른 도메인에 요청을 보낼 때는 CORS(Cross-Origin Resource Sharing) 정책에 따라 서버가 요청을 허용해야 합니다. 서버에서 적절한 CORS 헤더를 설정하지 않으면 브라우저에서 요청이 차단될 수 있습니다. - 비동기 처리 : `XMLHttpRequest`는 비동기적으로 동작하므로, 요청이 완료되기 전에 다음 코드가 실행될 수 있습니다. 따라서 응답 데이터를 처리하는 코드는 `onreadystatechange` 또는 `onload` 이벤트 핸들러 내에 작성해야 합니다. - 상태 코드 : HTTP 응답 상태 코드를 확인하여 요청이 성공적으로 처리되었는지 확인해야 합니다. 일반적으로 200번대 코드는 성공을 의미하며, 400번대 및 500번대 코드는 오류를 나타냅니다. 결론 `XMLHttpRequest`는 웹 애플리케이션에서 서버와의 통신을 가능하게 해주는 중요한 도구입니다. 비동기 요청을 통해 사용자 경험을 향상시키고, 페이지를 새로 고치지 않고도 데이터를 동적으로 업데이트할 수 있습니다. 그러나 최신 웹 개발에서는 `fetch` API와 같은 더 간단하고 직관적인 방법이 많이 사용되고 있으므로, 새로운 프로젝트에서는 `fetch`를 고려하는 것이 좋습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기