sitelink1  
sitelink2  
sitelink3  
sitelink4  
extra_vars4  
extra_vars5  
extra_vars6  

onreadystatechange에 등록된 callback fuction은 readyState라는 프로퍼티의 값이 변경될 때마다 호출됨


* readyState 상태

 값

 설명

 의미

 0

 객체만 생성 (open 메서드가 호출되지 않음)

 UnInitialized

 1

 open 메서드가 호출되고 아직 send 메서드가 불리지 않은 상태

 Loading

 2

 send메서드 호출, status아 헤더가 도착하지 않은 상태

 Loaded

 3

 데이터의 일부를 받은 상태

 Interactive

 4

 데이터 전부 받은 상태, 완전한 데이터의 이용 가능

 Completed


* status/stateText - 서버로부터의 응답상태.    

 값(status)

 텍스트(statusText)

설 명 

 200

 OK

 요청 성공

 403

 Forbidden

 접근 거부

 404

 Not Found

 페이지 없슴

 500

 Internal Server Error

 서버 오류 발생



Example>

httpRequest.onreadystatechange = callbackFunction;

httpRequest.open("GET", "/test.JSP", ture);

httpRequest.send(null); //요청을 보내고

...


//서버에서 응답을 받은 후 수행하는 함수를 콜백 함수라 한다.

function callbackFunction() //요청을 받는다.

{

     //서버에서 응답온 후 적절한 작업을 수행

    if(httpRequest.readyState == 1 || httpRequest.readyState == 2 || httpRequest.readyState == 3)

    {

        // 서버에서 처리 시간이 길어져 응답이 늦게 도착할때 이 상태를 이용해서 현재 서버가 처리중임을 알리는 내용을 화면에 출력한다.

        // 단 브라우저마다 readyState의 2, 3 번 값이 틀리기 때문에 크로스 브라우저를 지원하기 위해서는 1번과 4번만 사용하는 것이 유용하다.

    }

    else if(httpRequest.readyState == 4)

    {

         //서버로부터 응답이 도착

    }

}