k

비 전문가를 위한 XMLHttpRequest 활용 소개.

http://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=ajax&wr_id=6&page=2
에 배틀제이 님이 올려주신 예제로 소개해 드리겠습니다.
의외로 쉽고 활용도가 높습니다.

<script language="JavaScript">

function getHttprequest(URL) {
// 기본적인 변수 선언
var xmlhttp = null;
// FF일 경우 window.XMLHttpRequest 객체가 존재한다.
if(window.XMLHttpRequest) {
// FF 로 객체선언
xmlhttp = new XMLHttpRequest();
} else {
// IE 경우 객체선언
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}

// GET 모드로 URL 주소의 값을 가져온다
// 주의 해야 할점은 무조건 UTF 로 값이 들어옴
xmlhttp.open('GET', URL,false);

// 값을 가져 왔을경우 호출할 메소드를 바로 선언
xmlhttp.onreadystatechange = function() {

// readyState 가 4 고 status 가 200 일 경우 올바르게 가져옴
if(xmlhttp.readyState==4 && xmlhttp.status == 200 && xmlhttp.statusText=='OK') {
// responseText 에 값을 저장
responseText = xmlhttp.responseText;
}
}
xmlhttp.send('');

// 가져온 xmlhttp 객체의 responseText 값을 반환
return responseText = xmlhttp.responseText;
}



function replace(URL) {
document.getElementById('replace_area').innerHTML = getHttprequest(URL);
}

</script>

<div id='replace_area'> 냐하하~~ </div>

<a href = 'javascript:replace('test.php?bo_table=<?=bo_table?>&wr_id=<?=$wr_id?>');'> 가져오기 </a>


위 소스는 '가져오기' 를 클릭시 'test.php' 를 통해 출력되는 결과를 innerHTML 로
<div id='replace_area'></div> 속에 넣게 됩니다. '냐하하' 는 사라 지겠죠.

이때 화면의 리로드는 일어 나지 않으면서 출력 화면을 변화 시킬 수 있습니다.
즉 필요한 데이터만 가져다가 화면에 뿌려 줄 수 있다는 점이 장점입니다.

기존에 팝업창으로 해결해야 했던 부분들을 이러한 방법으로 화면내에 처리 할 수 있고,
실시간으로 테이터를 리플레쉬 할 수 도 있는 등 써 먹을때가 무척 많습니다.

단 주의하실 점은 XMLHttpRequest 로 받아 오는 데이터가 UTF-8 로 출력되기에 본인의 환경에 맞게
iconv 등을 통해서 EUC-KR 등으로 변환하는 과정이 필요합니다.


ob_start();
줄줄이 내용~~~~~~
$data = ob_get_contents();
ob_end_clean();
echo iconv("CP949", "UTF-8", $data);
요런게 한 방법이 되겠죠?
( 반대로 한글 변수를 전달 시에는 UTF-8 로 변환 전송 해야합니다. )

그리고 그냥 innerHTML 로 삽입시 가져온 문서에 스크립트가 있는 경우 작동을 안하는 경우가
있는데 <script DEFER language="JavaScript"> 식으로 DEFER 을 넣으면 되기도 하던데,
전문가가 아니라 잘 모르겠네요.

저 같이 프로그램 전문가가 아닌 분들을 위해 함 적어 봤습니다.
혹 오류 있으면 지적 부탁드리고요. ajax 란게 어려워 보여도 좋은 소스들이 많이 나와 있어서
그러한 소스들 적용하는 방법만 익히는 거라면 그리 어렵지는 않은 거 같습니다.<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:49:28 Prototype에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
19년 전 조회 2,802
19년 전 조회 2,811
19년 전 조회 3,159
19년 전 조회 3,030
19년 전 조회 2,699
19년 전 조회 2,917
19년 전 조회 3,166
19년 전 조회 2,868
19년 전 조회 2,603
19년 전 조회 2,913
19년 전 조회 4,493
19년 전 조회 2,419
19년 전 조회 2,438
19년 전 조회 3,475
19년 전 조회 3,145
19년 전 조회 2,798
19년 전 조회 2,041
19년 전 조회 1,765
19년 전 조회 2,871
19년 전 조회 1,713
19년 전 조회 2,305
19년 전 조회 3,945
19년 전 조회 3,724
19년 전 조회 3,443
19년 전 조회 3,397
19년 전 조회 1,557
19년 전 조회 1,926
19년 전 조회 1,849
19년 전 조회 2,515
19년 전 조회 4,611
19년 전 조회 2,748
19년 전 조회 1,910
19년 전 조회 1,921
19년 전 조회 1,807
19년 전 조회 2,547
19년 전 조회 8,168
19년 전 조회 2,718
19년 전 조회 2,780
19년 전 조회 3,035
19년 전 조회 2,188
19년 전 조회 2,203
19년 전 조회 2,167
19년 전 조회 2,063
19년 전 조회 2,252
19년 전 조회 2,509
19년 전 조회 3,073
19년 전 조회 2,325
19년 전 조회 1,901
19년 전 조회 2,825
19년 전 조회 4,990
19년 전 조회 3,490
19년 전 조회 3,447
19년 전 조회 2,969
19년 전 조회 2,390
19년 전 조회 1,480
19년 전 조회 3,129
19년 전 조회 2,002
19년 전 조회 5,364
19년 전 조회 2,420
19년 전 조회 3,423
19년 전 조회 2,847
19년 전 조회 1,756
19년 전 조회 3,872
19년 전 조회 2,410
19년 전 조회 2,292
19년 전 조회 3,014
19년 전 조회 3,289
19년 전 조회 2,488
19년 전 조회 2,254
19년 전 조회 2,321
19년 전 조회 1,990
19년 전 조회 3,083
19년 전 조회 2,007
19년 전 조회 2,039
19년 전 조회 1,692
19년 전 조회 2,205
19년 전 조회 2,181
19년 전 조회 2,475
19년 전 조회 2,870
19년 전 조회 2,378
19년 전 조회 2,446
19년 전 조회 3,497
19년 전 조회 3,209
19년 전 조회 3,200
19년 전 조회 3,007
19년 전 조회 2,023
19년 전 조회 2,335
19년 전 조회 2,222
19년 전 조회 2,054
19년 전 조회 2,492
19년 전 조회 2,408
19년 전 조회 2,791
19년 전 조회 2,167
19년 전 조회 3,496
19년 전 조회 1,961
19년 전 조회 2,571
19년 전 조회 1,589
19년 전 조회 2,819
19년 전 조회 3,059
19년 전 조회 2,142
🐛 버그신고