Framework/Spring

Ajax :: Ajax (Asynchronos JavaScript And XML)

초록 (green) 2017. 1. 10. 15:04

1. 정의

Asynchronos JavaScript And XML

비동기 자바스크립트와 XML을 뜻함

html form을 이용하지 않고 자바스크립트를 통해 서버에 데이터를 요청하는 것

서버 측의 스크립트와 통신하기 위한 XMLHttpRequest 객체를 사용하는 것

서버에서 로딩된 데이터를 페이지에 보여주기 위해 새로운 html 페이지로 갈 필요도 없고, 새로고침을 할 필요도 없음

=> 부분 부분만 로딩되므로 다소 속도가 빠름(비동기성)

 

* Asynchronos : 비동기적

  클라이언트 > 서버로 요청시 요청을 보내놓고 프로그램은 계속 돌아간다는 의미

  먼저 요청한 것에 대한 callback 함수가 먼저 실행되지 않음

 

* 자바스크립트는 웹 브라우저에 대한 스크립트 언어이기 때문에 서버와의 소통 기능은 없으나 ajax는 소통이 가능함

 

* XML : Extensible Markup Language

 데이터 형식의 일종. 확장이 가능한 표시 언어

 

* Markup Language : 데이터에 태그로 항목 표시를 해줌

<person>

<name> ~ </name>

<age> ~ </age>

</person>

 

* XML > Ajax

 

독립적인 기술이라기 보다는, 여러 기술의 묶음을 지칭하는 용어에 가까움

=> html, css, DOM, JS, XML, XSLI, XPath, XMLHttpRequest 등의 기술들이 사용됨

 

마이크로소프트 사에서 처음으로 만든 프레임워크

 

* Ajax의 본래 명칭 : XHR (XML http Request). http request를 서버에 보내는 것

  xml은 JS에서 사용하기에는 다소 불편함 점이 있기 때문에 JS로 서버에 요청을 보낼 시에는 주로 JSON을 많이 사용함

 


* Ajax로 request를 여러개 만들었을 경우, 어떤게 먼저 돌아올지 알 수 없기 때문에 어떤 callback이 먼저 실행될지 알 수 없음

 

 

2. 순서

ㄱ. XHR 객체 생성 : XMLHttpRequest Object 생성

ㄴ. callback 생성

ㄷ. html 메소드, url 결정 : open a request

ㄹ. XHR 메소드로 정보 발송 : send a request

 

 

3. 예제

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>ex02</title>
<script type="text/javascript">
    function loadDoc() {
//      ajax 사용하려면 브라우저 내장 함수로 XMLHttpRequest 객체 생성해야 함
//      (과거에는 ActiveXObject라는 생성자 사용하였음)
        var xhr = new XMLHttpRequest();
        
//      통신 후 성공, 실패에 따른 처리가 필요할 경우 서버가 응답했을 때 callback으로 호출되는 property에 함수를 할당하면 됨
//      1. XMLHttpRequest.onreadystatechange() 메소드 이용
//      2. XMLHttpRequest의 이벤트 핸들러를 이용
//      3. EventTarget.addEventListener() 메소드 이용
 
//      XMLHttpRequestEventTarget > XMLHttpRequest
//      <상속 받는 메소드>
//      - onabort() : abort 이벤트 발생시 호출
//      - onerror() : 서버 응답이 200이 아닐 때 호출
//      - onloadstart() : XHR 요청을 시작할 때 호출
//      - onloadend() : XHR 요청이 완료되면 호출됨. onload() 와 다르게 성공/실패 상관 없이 호출됨
//      - onprogres() : onloadstart()와 onloadend() 사이에 호출됨. 파라미터로 ProgressEvent를 전달 받으며 이 객체의 프로퍼티는
//                      브라우저마다 다를 수 있음
//      - onload() : XHR 요청이 성공적으로 완료되면 호출됨. XHR.status가 200일 때만 호출되는 메소드
//      - ontimeout : XHR.timeout으로 설정한 시간 내에 응답이 도착하지 않으면 호출됨.
//                    요청은 실패한 것으로 간주되며 onprogress()와 onload()는 호출되지 않음

 

//      onreadystatechange() : XMLHttpRequest의 프로퍼티로 콜백 함수를 저장함
//                             readyState의 값이 변할 때마다 호출되기 때문에 그대로 실행하면 안 됨
//                             (readyState의 값을 체크하는 조건 분기를 추가해야 원하는 결과를 얻을 수 있음)
        xhr.onreadystatechange = function() {
//          XHLHttpRequest.readyState : XMLHttpRequest의 현재 상태를 의미
//          - 0 : request not initialized
//          - 1 : server connection established
//          - 2 : request received
//          - 3 : progressing request
//          - 4 : request finished and response is ready
 
//          XHLHttpRequest.status : 응답 상태 코드를 숫자로 리턴함(200 : 정상)
            if (xhr.readyState == 4 && xhr.status == 200) {
                document.getElementById("demo").innerHTML = xhr.responseText;
            }
        };
        
//      XMLHttpRequest.open(method, url[, async])        
//      open() : Request의 유형을 지정함. send()로 메세지를 날리기 전, 어디에 어떤 방식으로 작동하는지 정하는 메소드
//               method, url은 필수지만 async는 기본값이 true로 생략할 수 있는 항목
//               async = false인 경우 send() 후 스크립트 진행을 중단하며 서버로부터 응답이 올 때까지 대기함
//      method : HTTP 메소드 타입(get, post)
//      url : 서버 경로
//      async : 비동기 여부(true, false)
        xhr.open("GET""ex03.jsp");
//      XMLHttpRequest.send([string]) : 폼 데이터로 전송할 문자열을 인자로 넣어 보냄
//      send() : 서버로 request 송신. open() 메소드에서 설정한 값에 따라 서버로 데이터를 요청함
//               string은 HTTP 메소드 타입이 POST일 경우에만 명시하며 폼 데이터로 간주됨
//               POST 방식일 때에는 setRequestHeader() 메소드로 컨텐츠 타입을 지정하지 않으면 서버에서 처리가 불가능함
//               string은 반드시 쿼리 스트링 형태로 작성되어야 함
        xhr.send();
    }
</script>
</head>
<body>
    <button onclick="loadDoc()">who r u</button>
    <div id="demo"></div>
</body>
</html>
cs

 

1
2
3
4
5
6
7
8
9
10
11
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>ex03</title>
</head>
<body>
    <h2>i am waldo</h2>
</body>
</html>
cs

 

 

 

<자바스크립트 + ajax를 이용한 예제>