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>
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 530 |
|
19년 전 | 1221 | |
| 529 |
|
19년 전 | 1396 | |
| 528 |
|
19년 전 | 1961 | |
| 527 |
사랑과우정
|
19년 전 | 2384 | |
| 526 | 19년 전 | 2861 | ||
| 525 |
|
19년 전 | 2289 | |
| 524 |
|
19년 전 | 1786 | |
| 523 | 19년 전 | 7020 | ||
| 522 |
|
19년 전 | 3709 | |
| 521 | 19년 전 | 2319 | ||
| 520 | 19년 전 | 2347 | ||
| 519 | 19년 전 | 2834 | ||
| 518 |
|
19년 전 | 5759 | |
| 517 |
|
19년 전 | 5536 | |
| 516 |
|
19년 전 | 2239 | |
| 515 |
|
19년 전 | 3277 | |
| 514 | 19년 전 | 2848 | ||
| 513 | 19년 전 | 2202 | ||
| 512 |
개발자관리자
|
19년 전 | 2715 | |
| 511 |
개발자관리자
|
19년 전 | 1567 | |
| 510 |
개발자관리자
|
19년 전 | 1722 | |
| 509 |
개발자관리자
|
19년 전 | 1815 | |
| 508 |
개발자관리자
|
19년 전 | 1990 | |
| 507 |
개발자관리자
|
19년 전 | 1668 | |
| 506 |
개발자관리자
|
19년 전 | 1795 | |
| 505 |
개발자관리자
|
19년 전 | 1763 | |
| 504 |
개발자관리자
|
19년 전 | 1833 | |
| 503 |
개발자관리자
|
19년 전 | 1510 | |
| 502 |
개발자관리자
|
19년 전 | 2631 | |
| 501 | 19년 전 | 1972 | ||
| 500 | 19년 전 | 3223 | ||
| 499 | 19년 전 | 3248 | ||
| 498 | 19년 전 | 2506 | ||
| 497 | 19년 전 | 2594 | ||
| 496 | 19년 전 | 2429 | ||
| 495 | 19년 전 | 2685 | ||
| 494 | 19년 전 | 2668 | ||
| 493 | 19년 전 | 3147 | ||
| 492 | 19년 전 | 2865 | ||
| 491 | 19년 전 | 5275 | ||
| 490 |
|
19년 전 | 2099 | |
| 489 |
|
19년 전 | 2187 | |
| 488 |
|
19년 전 | 1992 | |
| 487 |
|
19년 전 | 1922 | |
| 486 |
|
19년 전 | 1925 | |
| 485 |
|
19년 전 | 2117 | |
| 484 |
|
19년 전 | 3187 | |
| 483 |
|
19년 전 | 3060 | |
| 482 |
|
19년 전 | 2829 | |
| 481 |
|
19년 전 | 2530 | |
| 480 |
|
19년 전 | 2616 | |
| 479 |
|
19년 전 | 2280 | |
| 478 |
|
19년 전 | 2318 | |
| 477 |
개발자관리자
|
19년 전 | 1574 | |
| 476 |
개발자관리자
|
19년 전 | 2300 | |
| 475 |
개발자관리자
|
19년 전 | 2648 | |
| 474 |
개발자관리자
|
19년 전 | 2642 | |
| 473 |
개발자관리자
|
19년 전 | 2946 | |
| 472 | 19년 전 | 2725 | ||
| 471 | 19년 전 | 1697 | ||
| 470 | 19년 전 | 1805 | ||
| 469 |
|
19년 전 | 2705 | |
| 468 |
|
19년 전 | 2206 | |
| 467 |
|
19년 전 | 3970 | |
| 466 |
|
19년 전 | 2479 | |
| 465 | 19년 전 | 2363 | ||
| 464 | 19년 전 | 3509 | ||
| 463 |
|
19년 전 | 3086 | |
| 462 |
|
19년 전 | 2226 | |
| 461 |
|
19년 전 | 3020 | |
| 460 |
|
19년 전 | 2225 | |
| 459 |
|
19년 전 | 3082 | |
| 458 |
|
19년 전 | 3506 | |
| 457 |
|
19년 전 | 5194 | |
| 456 |
|
19년 전 | 3118 | |
| 455 |
스마일미디어
|
19년 전 | 3113 | |
| 454 |
스마일미디어
|
19년 전 | 2690 | |
| 453 |
스마일미디어
|
19년 전 | 2441 | |
| 452 |
스마일미디어
|
19년 전 | 2699 | |
| 451 |
스마일미디어
|
19년 전 | 2426 | |
| 450 |
스마일미디어
|
19년 전 | 2541 | |
| 449 |
스마일미디어
|
19년 전 | 2341 | |
| 448 |
스마일미디어
|
19년 전 | 2681 | |
| 447 | 19년 전 | 2949 | ||
| 446 |
스마일미디어
|
19년 전 | 3234 | |
| 445 |
스마일미디어
|
19년 전 | 7034 | |
| 444 |
스마일미디어
|
19년 전 | 5158 | |
| 443 |
스마일미디어
|
19년 전 | 2412 | |
| 442 |
스마일미디어
|
19년 전 | 5140 | |
| 441 |
스마일미디어
|
19년 전 | 3087 | |
| 440 |
|
19년 전 | 2436 | |
| 439 | 19년 전 | 2128 | ||
| 438 | 19년 전 | 3553 | ||
| 437 |
|
19년 전 | 2865 | |
| 436 |
|
19년 전 | 3242 | |
| 435 |
|
19년 전 | 2864 | |
| 434 | 19년 전 | 3368 | ||
| 433 |
sjsjin
|
19년 전 | 2689 | |
| 432 |
sjsjin
|
19년 전 | 3446 | |
| 431 |
sjsjin
|
19년 전 | 2403 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기