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>
에 배틀제이 님이 올려주신 예제로 소개해 드리겠습니다.
의외로 쉽고 활용도가 높습니다.
<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>
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 930 | 19년 전 | 3545 | ||
| 929 |
|
19년 전 | 2707 | |
| 928 |
|
19년 전 | 3455 | |
| 927 |
|
19년 전 | 3444 | |
| 926 |
|
19년 전 | 3149 | |
| 925 | 19년 전 | 5434 | ||
| 924 |
|
19년 전 | 2170 | |
| 923 |
|
19년 전 | 2225 | |
| 922 |
|
19년 전 | 2316 | |
| 921 |
|
19년 전 | 3412 | |
| 920 | 19년 전 | 3709 | ||
| 919 |
|
19년 전 | 3749 | |
| 918 |
|
19년 전 | 2366 | |
| 917 |
|
19년 전 | 2400 | |
| 916 |
|
19년 전 | 2707 | |
| 915 | 19년 전 | 3051 | ||
| 914 | 19년 전 | 2463 | ||
| 913 | 19년 전 | 2627 | ||
| 912 | 19년 전 | 2462 | ||
| 911 | 19년 전 | 2216 | ||
| 910 | 19년 전 | 3249 | ||
| 909 | 19년 전 | 3311 | ||
| 908 | 19년 전 | 3042 | ||
| 907 |
|
19년 전 | 4876 | |
| 906 |
|
19년 전 | 2719 | |
| 905 |
|
19년 전 | 3319 | |
| 904 |
|
19년 전 | 3154 | |
| 903 |
|
19년 전 | 1997 | |
| 902 |
|
19년 전 | 3147 | |
| 901 |
|
19년 전 | 1881 | |
| 900 |
|
19년 전 | 2340 | |
| 899 |
|
19년 전 | 2404 | |
| 898 |
|
19년 전 | 3986 | |
| 897 |
|
19년 전 | 3188 | |
| 896 |
|
19년 전 | 3106 | |
| 895 |
|
19년 전 | 2542 | |
| 894 |
|
19년 전 | 2019 | |
| 893 |
|
19년 전 | 1651 | |
| 892 |
|
19년 전 | 2419 | |
| 891 |
|
19년 전 | 2330 | |
| 890 |
|
19년 전 | 1816 | |
| 889 |
|
19년 전 | 1813 | |
| 888 |
|
19년 전 | 2613 | |
| 887 |
|
19년 전 | 2584 | |
| 886 |
|
19년 전 | 1876 | |
| 885 |
|
19년 전 | 2116 | |
| 884 |
|
19년 전 | 3307 | |
| 883 |
|
19년 전 | 1955 | |
| 882 |
|
19년 전 | 2503 | |
| 881 |
|
19년 전 | 2582 | |
| 880 |
|
19년 전 | 2664 | |
| 879 |
|
19년 전 | 2939 | |
| 878 |
|
19년 전 | 2561 | |
| 877 |
|
19년 전 | 2984 | |
| 876 |
|
19년 전 | 2762 | |
| 875 |
|
19년 전 | 3524 | |
| 874 | 19년 전 | 1873 | ||
| 873 | 19년 전 | 2736 | ||
| 872 |
|
19년 전 | 2376 | |
| 871 |
|
19년 전 | 2020 | |
| 870 |
|
19년 전 | 2427 | |
| 869 |
|
19년 전 | 1873 | |
| 868 |
|
19년 전 | 5441 | |
| 867 |
|
19년 전 | 2266 | |
| 866 |
|
19년 전 | 4265 | |
| 865 |
|
19년 전 | 2304 | |
| 864 | 19년 전 | 1854 | ||
| 863 | 19년 전 | 2608 | ||
| 862 | 19년 전 | 2335 | ||
| 861 | 19년 전 | 2536 | ||
| 860 | 19년 전 | 2165 | ||
| 859 | 19년 전 | 3929 | ||
| 858 | 19년 전 | 3422 | ||
| 857 | 19년 전 | 2199 | ||
| 856 |
Power
|
19년 전 | 2109 | |
| 855 | 19년 전 | 1972 | ||
| 854 | 19년 전 | 2006 | ||
| 853 |
pearly
|
19년 전 | 4391 | |
| 852 |
pearly
|
19년 전 | 3358 | |
| 851 | 19년 전 | 2779 | ||
| 850 |
pearly
|
19년 전 | 3355 | |
| 849 |
pearly
|
19년 전 | 3015 | |
| 848 |
pearly
|
19년 전 | 2845 | |
| 847 | 19년 전 | 2369 | ||
| 846 |
|
19년 전 | 2177 | |
| 845 |
pearly
|
19년 전 | 2496 | |
| 844 | 19년 전 | 3105 | ||
| 843 | 19년 전 | 2134 | ||
| 842 |
pearly
|
19년 전 | 3125 | |
| 841 |
pearly
|
19년 전 | 3249 | |
| 840 | 19년 전 | 2930 | ||
| 839 |
|
19년 전 | 1945 | |
| 838 |
|
19년 전 | 1708 | |
| 837 |
|
19년 전 | 2330 | |
| 836 |
|
19년 전 | 2273 | |
| 835 |
|
19년 전 | 1649 | |
| 834 |
|
19년 전 | 1667 | |
| 833 |
|
19년 전 | 1575 | |
| 832 |
|
19년 전 | 2068 | |
| 831 |
|
19년 전 | 1617 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기