RadarURL

웹 프로그래밍
2007.05.10 22:36

XMLHttpRequest 메서드 및 속성 정리

조회 수 4600 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄




[01호] AJAX AJAX

2007/02/20 13:36



http://blog.naver.com/wesable/34623361



AJAX 를 구현하려면 XMLHttpRequest 객체부터 생성해야 한다.


 


XMLHttpRequest 객체는 최초 IE5에서 ActiveX Component 형식으로 먼저 제공되었으며 현재 대부분의 브라우저들이 지원하고 있다. XMLHttpRequest는 W3C의 표준이 아니므로 IE 는 ActiveX 형식으로, 다른 브라우저(FIreFox, Safari, Opera등)은 Native Javascript로 구현되었다.)


 


AJAX 요소 기술로는 앞서 얘기한 XMLHttpRequest를 필두로 XHTML,CSS,XML,XLST,Javascript,DOM 등이 사용되며, Javascript가 ECMA표준이며 다른 기술은 W3C표준이므로, 모든 브라우저 개발 업체/단체의 합의하에 통용되는 표준으로 자리매김되어 있다.


 


 


 


먼저 AJAX 초기화하려면 아래와같이 두개로 나눠서 해야한다.


위에서 설명한대로 IE 와 타 브라우저가 다르게 지원하기때문에 모두에 맞추려면 아래와같이 나눠서 처리해줘야 한다.





function createXMLHttpRequest() {
 var xmlHttp = null;
 if (window.ActiveXObject) {
  xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
 }
 else if (window.XMLHttpRequest) {
  xmlHttp = new XMLHttpRequest();
 }
 
 if (xmlHttp == null)
  alert("XML 객체를 생성하지 못했습니다.");
 
 return xmlHttp;
}






 


이것을 쓰기위해서는 아래와같이 오브젝트의 onreadystatechange 속성 에 이벤트를 걸어서 사용하는방법이 많이 사용된다.







 var xmlObj = createXMLHttpRequest();
 xmlObj.open("GET","[URL]");
 xmlObj.send();
 xmlObj.onreadystatechange = function() {
  if (xmlObj.readyState == 4) {
     [처리구문...]
  }
 }





 


 


 


이렇게 초기화 하고나면 처리를 해야하는데 처리 하기위한 메소드와 속성들을 알아보자.


 


- Method







- void open(String method,String url, boolean asynch, String username,String password)


: 요청을 초기화한다.


* method - 'POST','GET','PUT' 중 하나를 사용(필수)


* url - 요청 서버의 url (필수)


* asynch - true(default), false 설정(서버 응답까지 대기)


 


- void send(content)


: 요청을 서버로 보낸다. 비동기시 요청한다음 끝이지만 동기시면 응답 받을때까지 대기한다.


* content - DOM 객체(XML 객체)이거나 input stream,String 값등으로 설정


open() Parameter의 method 값이 'POST'로 설정되어 있으면


HttpRequest body에 포함되어 서버로 전달된다.


GET방식으로 요청하려면 null 을 설정하면 된다.


 


- void setRequestHeader(string header,String value)


: open() 다음에 위치해서 HttpRequest 헤더에 value를 설정하는 메소드


 


- void abort() : 요청을 중지한다.


 


- string getAllResponseHeaders()


: 요청에 대응되는 응답의 헤더정보를 리턴한다.


즉, Content-Length, Date, URI 등을 포함하는 헤더정보를 string 형식으로 반환한다.


 


- string getResponseHeader(string header)


: 응답의 헤더정보중에서 header 에 대응되는 값을 string 형식으로 반환한다.







 


- Attribute







- onreadystatechange


: 자바스크립트 콜백함수(function pointer) 를 저장한다.


이 함수는 readyState 값이 변할때 마다 호출된다.


 


- readyState


: 현재 요청의 상태를 의미한다.


상태는 아래와같이 다섯가지가 있다.





























코드


상태


설명


0


UNINITIALIZED


XMLHttpRequest 객체를 생성하였지만, 초기화되지 않았다.


, open() 메소드를 실행하지 않은 상태


1


LOADING


XMLHttpRequest 객체를 생성하였고, open() 메소드를 수행하였지만, send() 메소드를 수행하지 않은 상태


2


LOADED


send() 메소드를 수행하였지만, 서버가 처리를 준비하고 있는 상태


3


INTERACTIVE


처리를 완료하지 않았지만, 진행 중인 상태


4


COMPLETED


처리를 완료한 상태


 


- responseText


: 서버의 응답을 string 형식으로 나타낸다.


그냥 단순히 내용을 text 로 돌려준다.


 


- responseXML


: 서버의 응답을 XML로 나타낸다.


이 속성은 DOM객체로 파싱할 수 있다.


 


- status


: 서버로부터의 HTTP 상태코드


200 - OK


404 - NOT Found


202 - 결과 값이 없을때


등등...


 


- statusText


: HTTP 상태코드에 대한 텍스트 값이다.


OK, NOT Found 등등...






 


 


 


자 이제 덤으로 DOM 을 알아보자.


파싱을 하려면 어쩔수없이 써야하는거다.


 


 


- Method







- selectSingleNode(xpath)


: 특정 노드를 xpath 를 이용해 검색해서 단일레코드를 돌려준다.


 


- selectNodes(xpath)


: 특정 노드를 xpath 를 이용해 검색해서 매칭된 레코드들을 돌려준다.


 여기서 xpath 란 xml 상의 정규식 이라고 보시면 된다.


 


- getElementById(id)


: document 에서 특정한 ID 속성값을 가지고있는 요소를 반환한다.


 


- getElementsByTagName(name)


: 특정한 태그 이름을 가지고있는 자식요소로 구성된 배열을 리턴한다.


 


- hasChildNodes()


: 자식요소가 있는지 없는지 boolean 을 리턴한다.


 


- getAttribute(name)


: 해당 요소의 속성값을 리턴한다.


 


- appendChild(childNode)


: 특정 노드를 현재 엘리먼트의 자식 노드에 추가시킨다.


 


- setAttribute(name,value)


: 속성값을 지정한다.


 


- insertBefore(newNode,targetNode)


: newNode targetNode 앞에 삽입한다.


 


- removeAttribute(name)


: 해당 요소의 name 속성을 제거한다.


 


- removeChild(childNode)


: 자식 요소를 제거한다.


 


- replaceChild(newNode, oldNode)


: oldNode 를 newNode 로 치환한다.


 


- document.createElement(tagName)


: 해당 태그명으로된 요소를 생성한다 (table 를 주면 table 요소가 생성된다.)


 


- document.createTextNode(text)


: 정적 텍스트를 담고있는 노드를 생성한다.







 


- Attribute







childNodes : 현재 요소의 자식을 배열로 표현한다.


firstChild : 현재 요소의 첫번째 자식이다.


lastChild : 현재 요소의 마지막 자식이다.


nextSibling : 현재 요소와 바로 다음 요소를 의미한다.


text : 해당 요소의 값을 읽고 쓸 수 있는 속성을 정의한다. (==data,==nodeValue)


parentNode : 해당 요소의 부모노드이다.


previousSibling : 현재 요소와 바로 이전의 요소를 의미한다.







 


 

20061109 본문 이미지 Resizing --> 20061109 본문 이미지 Resizing END -->













Copyright ⓒ 크래닉스의 프로그래밍 이야기 All Rights Reserved

출처 : Tong - 난신기루다~★님의 Ajax통

출처 : http://tong.nate.com/singiruda/37192793

?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 928100
346 응용 프로그래밍 WIndows Application의 실행 속도 측정 file JaeSoo 2023.09.06 3185
345 웹 프로그래밍 메모리 부족 현상 (allowed memory size of 134217728 bytes..) JaeSoo 2023.08.01 2207
344 웹 프로그래밍 Guzzle - cURL error 60: SSL certificate problem: unable to get local issuer certificate 문제 해결 file JaeSoo 2023.07.30 2188
343 웹 프로그래밍 XE 캐시파일 재성생후 404 Oops, Sorry. Page is not found! 나올때 JaeSoo 2023.07.29 2117
342 응용 프로그래밍 [Apple] 엔터프라이즈 계정신청 (Enterprise Program) file JaeSoo 2023.03.27 267
341 웹 프로그래밍 XE - " Fatal error: Class 'Object' not found in " / class 낫파운드 오류 file JaeSoo 2023.03.20 147
340 응용 프로그래밍 [MSA] MSA란 무엇인가? 개념 이해하기 file JaeSoo 2023.01.26 210
339 웹 프로그래밍 iOS 앱 개발을 위한 인증서 생성 및 관리 file JaeSoo 2023.01.18 218
338 프로그래밍 [ iOS ] 앱 스토어 개인, 회사, 엔터프라이즈 차이점 file JaeSoo 2023.01.09 237
337 웹 프로그래밍 PHP 파서 이해하기 (<?php의 php를 생략하고 간단히 <? 태그 와 ?> 태그를 사용하는 방법) JaeSoo 2016.08.10 322
336 프로그래밍 SVN의 cleanup 에러시 해결방법 JaeSoo 2016.05.05 728
335 프로그래밍 [오류해결] svn cleanup failed-previous operation has not finished; run cleanup if it was interrupted file JaeSoo 2016.05.05 611
334 프로그래밍 TortoiseSVN 계정변경 file JaeSoo 2016.05.05 582
333 프로그래밍 SVN passwd 설정 : 계정 (users/passwd) file JaeSoo 2016.05.04 543
332 웹 프로그래밍 XE 비회원 글쓰기 항목 지우기 file JaeSoo 2016.04.28 499
331 응용 프로그래밍 메모리 영역 (code, data, stack, heap) file JaeSoo 2016.03.23 747
330 응용 프로그래밍 [SVN] Subversion 명령들 file JaeSoo 2016.02.06 967
329 응용 프로그래밍 IBM JDK 1.6 에서 Spring 2.5.2를 사용할 때 GenericTypeResolver 에서 NullPointerException이 발생하는 문제 JaeSoo 2016.01.27 787
328 웹 프로그래밍 오른쪽 마우스 금지 소스 / 드래그 금지 소스 JaeSoo 2016.01.20 475
327 응용 프로그래밍 [전자정부 표준프레임워크] 톰캣(Tomcat) 설치하기 file JaeSoo 2016.01.02 535
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 18 Next
/ 18


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너