잠시만 기다려 주세요

     '대한민국이 더이상 발전하지 못하는 것은 부패한 언론들의 쓰레기짓 때문이다.'
전체검색 :  
이번주 로또 및 연금번호 발생!!   |  HOME   |  여기는?   |  바다물때표   |  알림 (16)  |  여러가지 팁 (1059)  |  추천 및 재미 (156)  |  자료실 (22)  |  
시사, 이슈, 칼럼, 평론, 비평 (613)  |  끄적거림 (136)  |  문예 창작 (716)  |  바람 따라 (75)  |  시나리오 (760)  |  드라마 대본 (248)  |  
살인!


    javascript/jquery

javascript/jquery - [jQuery] Ajax의 흐름과 예제
이 름 : 바다아이   |   조회수 : 11679         짧은 주소 : https://www.bada-ie.com/su/?51591810929

1. AJAX(Asynchronous Javascript and XML)란 무엇인가?

 

Ajax의 예를들면, 

네이버나 다음같은 포털사이트에 가보면, 

메인페이지에서 뉴스 등 밑에 < , > 요런 버튼을 눌렀을 때 페이지가 Reloading 되지 않고 뜨는걸 볼 수있다.

 

보통 웹의 흐름에서는 새로운 URL로 호출 되면서 페이지가 새로 뿌려지지만,

AJAX를 사용하면 일부만을 로드해올 수 있는 것이다.

이름처럼 비동기 통신을 통해서.

 

 

 

 

2. 어떤 원리이고 흐름인가?

 

보통 웹사이트 들어갈 때 어떻게 들어가는가?

브라우저 위에 주소창에 URL을 쓰고 들어간다. 그러면 브라우저가 그 URL(서버)로 연결시켜준다.

서버에서 받아온 데이터들을 브라우저가 받아서 파싱해서 뿌려준다.

 

이게 보통 웹의 흐름이라면,

 

AJAX는 AJAX 자체가 브라우저라고 생각하면 된다. 

URL을 받고, AJAX 내부에서 XMLHttpRequest 통신을 해서 URL(서버)로 연결시켜준다.

서버에서 받아온 데이터들을 AJAX가 받는다.  (어떻게 뿌릴지는 여기서 직접 알아서 한다 ㅋㅋ)

 

 

 

 

3. 예제

 

jQuery 같은 프레임워크를 안쓰고 AJAX 통신 하는 예제는 

http://mainia.tistory.com/314  <- 이 블로그 참조

 

jQuery를 이용하면 간단 명료하게 작성 가능하다.

 

 

 

<script  src="http://code.jquery.com/jquery-latest.min.js"></script>

 

<script>

$(document).ready(function() {

     jQuery.ajax({

           type:"GET",

           url:"/test",

           dataType:"JSON", // 옵션이므로 JSON으로 받을게 아니면 안써도 됨

           success : function(data) {

                 // 통신이 성공적으로 이루어졌을 때 이 함수를 타게 된다.

                 // TODO

           },

           complete : function(data) {

                 // 통신이 실패했어도 완료가 되었을 때 이 함수를 타게 된다.

                 // TODO

           },

           error : function(xhr, status, error) {

                 alert("에러발생");

           }

     });

});

</script>

 

 

 

 

<script  src="http://code.jquery.com/jquery-latest.min.js"></script>

이렇게 쓰면 jQuery의 항상 최신 버전을 쓸 수 있다.

 

 

보통 complete을 쓸 지, success를 쓸 지는 상황에 따라 다르다.

둘 중 하나만 써야함. 그냥 설명하기 위해 2개 쓴 것임.

(반드시 둘 중 하나만 써야하는건 아니고, 둘다 쓰면 두 번 호출되기 때문에)

 

 

 

 

 

4. 값 받아오기

 

success를 통해 받아온 값을 alert 으로 띄운다거나,

HTML 코드에 추가해서 나타내거나 여러가지 방법으로 보여지도록 할 수 있다.

 

JSON으로 받는 법을 정리하겠다

 

 

JSON 객체는 요렇게 생긴 객체임. 

 

 {"name": "lioncat", "age": 14, "nickname": "qwerty"}

 

 

 

서버 단에서는, 

객체에 있는 값을 JSON 형태로 만들어주는 라이브러리들이 있으니

서버는 그 것을 사용해서 JSON으로 리턴 하면된다.

 

클라이언트에서도 JSON으로 받아야 하는데,

3번 예제처럼 dataType:"JSON" 부분을 써주면 JSON으로 받아진다.

 

 

 

success에서 받아온 객체인 data를 alert으로 띄워보면

[Object object] 라고 나올 것이다.

 

저것을 어떻게 보느냐???

-> each 함수 사용해야 된다.    (자세한 each 사용법은 검색 ㄱㄱ)

 

// success나 complete 안에서 사용

 

$.each(data, function() {

     alert(this["name"]);

     alert(this.age);

});

 

또는

 

$.each(data, function(index, entry) {

     alert(entry["name"]);

     alert(entry.age);

});

 

 

 

* 참고로 jQuery를 사용하지 않은 순수 AJAX를 통해 데이터를 받아왔을 때는 eval 함수를 써야한다. 

jQuery의 AJAX에서는 자체적으로 JSON Object로 변환 시켜준 것이기 때문에 each로 쓸 수 있지만,

순수 AJAX에서는 JSON 객체로 변환되지 않았기 때문이다.


출처 : 
http://marobiana.tistory.com/77
 

| |





      1 page / 3 page
번 호 카테고리 제 목 이름 조회수
76 javascript/jquery , . 바다아이 7101
75 javascript/jquery , . , 바다아이 5297
74 javascript/jquery javascript , ... 바다아이 7034
73 javascript/jquery , cookie class 바다아이 7616
72 javascript/jquery select 3 바다아이 8589
71 javascript/jquery , ... 바다아이 7969
70 javascript/jquery , timezone, , ... moment.js 바다아이 10185
69 javascript/jquery textarea cursor . focus, cursor ... 바다아이 10238
68 javascript/jquery (block) , ... 바다아이 8349
67 javascript/jquery textarea cursor , , focus 바다아이 11499
66 javascript/jquery jquery ajax option .... 바다아이 8628
65 javascript/jquery jquery open api , ajax JSONP cross domain , , error 0 ... sop 바다아이 8395
64 javascript/jquery javascript , , , , () 바다아이 9262
63 javascript/jquery javascript (date ) 바다아이 9421
62 javascript/jquery CSS3 javascript 바다아이 10203
61 javascript/jquery javascript , cookie, , , , , 바다아이 9468
60 javascript/jquery javascript 바다아이 10075
59 javascript/jquery javascript / , , , 바다아이 13291
58 javascript/jquery url , , encode, decode ... 바다아이 8563
57 javascript/jquery javascript ... frame location.href 바다아이 14104
56 javascript/jquery File Upload Progress, .... . 바다아이 9014
55 javascript/jquery javascript, json , json Highlight 바다아이 9159
54 javascript/jquery javascript json , , JSON.stringify, JSON.parse, 바다아이 10471
53 javascript/jquery javascript innerHTML, innerTEXT ... 바다아이 9230
52 javascript/jquery javascript entity , , encode, decode 바다아이 9424
51 javascript/jquery javascript post, get , 바다아이 10727
50 javascript/jquery text copy, , How to copy a TEXT to Clipboard on a Button-Click 바다아이 9522
49 javascript/jquery jquery autocomplete , , . 바다아이 9100
48 javascript/jquery javascript, jquery, , autocomplete 바다아이 10085
47 javascript/jquery substring, substr, indexOf, lastIndexOf (javascript , , ) 바다아이 9351
| |









Copyright ⓒ 2001.12. bada-ie.com. All rights reserved.
이 사이트는 리눅스에서 firefox 기준으로 작성되었습니다. 기타 브라우저에서는 다르게 보일 수 있습니다.
[ Ubuntu + GoLang + PostgreSQL + Mariadb ]
서버위치 : 오라클 클라우드 춘천  실행시간 : 0.05916
to webmaster... gogo sea. gogo sea.