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>
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 230 | 20년 전 | 2053 | ||
| 229 | 20년 전 | 3132 | ||
| 228 | 20년 전 | 3322 | ||
| 227 | 20년 전 | 2388 | ||
| 226 | 20년 전 | 5472 | ||
| 225 | 20년 전 | 2516 | ||
| 224 | 20년 전 | 2963 | ||
| 223 | 20년 전 | 4201 | ||
| 222 | 20년 전 | 2604 | ||
| 221 | 20년 전 | 2287 | ||
| 220 | 20년 전 | 3673 | ||
| 219 | 20년 전 | 2065 | ||
| 218 | 20년 전 | 3562 | ||
| 217 | 20년 전 | 2473 | ||
| 216 | 20년 전 | 2905 | ||
| 215 | 20년 전 | 2219 | ||
| 214 | 20년 전 | 3332 | ||
| 213 | 20년 전 | 2911 | ||
| 212 | 20년 전 | 3045 | ||
| 211 | 20년 전 | 2143 | ||
| 210 | 20년 전 | 1889 | ||
| 209 | 20년 전 | 2345 | ||
| 208 | 20년 전 | 1972 | ||
| 207 | 20년 전 | 1670 | ||
| 206 | 20년 전 | 1852 | ||
| 205 | 20년 전 | 3943 | ||
| 204 | 20년 전 | 1672 | ||
| 203 | 20년 전 | 2006 | ||
| 202 | 20년 전 | 2353 | ||
| 201 | 20년 전 | 1820 | ||
| 200 | 20년 전 | 2950 | ||
| 199 | 20년 전 | 2004 | ||
| 198 | 20년 전 | 2083 | ||
| 197 | 20년 전 | 3648 | ||
| 196 | 20년 전 | 2976 | ||
| 195 | 20년 전 | 2088 | ||
| 194 | 20년 전 | 10239 | ||
| 193 | 20년 전 | 2240 | ||
| 192 | 20년 전 | 1594 | ||
| 191 | 20년 전 | 2660 | ||
| 190 | 20년 전 | 2285 | ||
| 189 | 20년 전 | 1679 | ||
| 188 | 20년 전 | 1472 | ||
| 187 | 20년 전 | 1903 | ||
| 186 | 20년 전 | 1706 | ||
| 185 | 20년 전 | 1748 | ||
| 184 | 20년 전 | 2343 | ||
| 183 | 20년 전 | 1553 | ||
| 182 | 20년 전 | 1481 | ||
| 181 | 20년 전 | 1621 | ||
| 180 | 20년 전 | 2716 | ||
| 179 | 20년 전 | 1797 | ||
| 178 | 20년 전 | 1851 | ||
| 177 | 20년 전 | 1977 | ||
| 176 | 20년 전 | 1797 | ||
| 175 | 20년 전 | 1870 | ||
| 174 | 20년 전 | 1692 | ||
| 173 | 20년 전 | 2057 | ||
| 172 | 20년 전 | 1781 | ||
| 171 | 20년 전 | 2553 | ||
| 170 | 20년 전 | 2266 | ||
| 169 | 20년 전 | 2546 | ||
| 168 | 20년 전 | 1471 | ||
| 167 | 20년 전 | 1574 | ||
| 166 | 20년 전 | 2145 | ||
| 165 | 20년 전 | 1617 | ||
| 164 | 20년 전 | 3764 | ||
| 163 | 20년 전 | 2655 | ||
| 162 | 20년 전 | 2076 | ||
| 161 | 20년 전 | 2785 | ||
| 160 | 20년 전 | 1729 | ||
| 159 | 20년 전 | 1602 | ||
| 158 | 20년 전 | 2560 | ||
| 157 | 20년 전 | 1486 | ||
| 156 | 20년 전 | 1732 | ||
| 155 | 20년 전 | 3226 | ||
| 154 | 20년 전 | 1885 | ||
| 153 | 20년 전 | 1618 | ||
| 152 | 20년 전 | 4945 | ||
| 151 | 20년 전 | 4570 | ||
| 150 | 20년 전 | 3510 | ||
| 149 | 20년 전 | 3780 | ||
| 148 | 20년 전 | 7067 | ||
| 147 | 20년 전 | 3547 | ||
| 146 | 20년 전 | 2617 | ||
| 145 | 20년 전 | 2609 | ||
| 144 | 20년 전 | 7164 | ||
| 143 | 20년 전 | 4594 | ||
| 142 | 20년 전 | 1898 | ||
| 141 | 20년 전 | 3249 | ||
| 140 | 20년 전 | 1957 | ||
| 139 | 20년 전 | 1568 | ||
| 138 | 20년 전 | 2298 | ||
| 137 | 20년 전 | 1774 | ||
| 136 | 20년 전 | 1450 | ||
| 135 | 20년 전 | 1782 | ||
| 134 | 20년 전 | 2964 | ||
| 133 | 20년 전 | 2442 | ||
| 132 | 20년 전 | 1704 | ||
| 131 | 20년 전 | 1636 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기