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>
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 630 | 19년 전 | 2346 | ||
| 629 |
|
19년 전 | 2006 | |
| 628 |
|
19년 전 | 3120 | |
| 627 |
|
19년 전 | 2030 | |
| 626 |
|
19년 전 | 2066 | |
| 625 |
|
19년 전 | 1718 | |
| 624 |
|
19년 전 | 2221 | |
| 623 | 19년 전 | 2195 | ||
| 622 |
|
19년 전 | 2507 | |
| 621 |
|
19년 전 | 2907 | |
| 620 |
|
19년 전 | 2403 | |
| 619 | 19년 전 | 2466 | ||
| 618 | 19년 전 | 3512 | ||
| 617 |
|
19년 전 | 3230 | |
| 616 |
|
19년 전 | 3219 | |
| 615 |
|
19년 전 | 3035 | |
| 614 |
|
19년 전 | 2043 | |
| 613 |
|
19년 전 | 2374 | |
| 612 |
|
19년 전 | 2237 | |
| 611 |
|
19년 전 | 2082 | |
| 610 |
|
19년 전 | 2514 | |
| 609 |
|
19년 전 | 2419 | |
| 608 |
|
19년 전 | 2807 | |
| 607 | 19년 전 | 2193 | ||
| 606 | 19년 전 | 3526 | ||
| 605 | 19년 전 | 1988 | ||
| 604 | 19년 전 | 2594 | ||
| 603 | 19년 전 | 1608 | ||
| 602 |
|
19년 전 | 2833 | |
| 601 | 19년 전 | 3074 | ||
| 600 |
|
19년 전 | 2153 | |
| 599 | 19년 전 | 1997 | ||
| 598 | 19년 전 | 2480 | ||
| 597 | 19년 전 | 2388 | ||
| 596 |
|
19년 전 | 3072 | |
| 595 |
|
19년 전 | 6751 | |
| 594 | 19년 전 | 2707 | ||
| 593 | 19년 전 | 3184 | ||
| 592 |
|
19년 전 | 3087 | |
| 591 |
|
19년 전 | 1929 | |
| 590 | 19년 전 | 3363 | ||
| 589 | 19년 전 | 2207 | ||
| 588 |
|
19년 전 | 2705 | |
| 587 | 19년 전 | 2343 | ||
| 586 |
|
19년 전 | 4361 | |
| 585 | 19년 전 | 2486 | ||
| 584 | 19년 전 | 2754 | ||
| 583 |
|
19년 전 | 3521 | |
| 582 |
|
19년 전 | 3717 | |
| 581 |
|
19년 전 | 3249 | |
| 580 | 19년 전 | 2483 | ||
| 579 | 19년 전 | 3069 | ||
| 578 | 19년 전 | 3965 | ||
| 577 | 19년 전 | 3807 | ||
| 576 | 19년 전 | 1743 | ||
| 575 |
|
19년 전 | 2207 | |
| 574 |
|
19년 전 | 5402 | |
| 573 | 19년 전 | 6713 | ||
| 572 | 19년 전 | 2561 | ||
| 571 | 19년 전 | 2103 | ||
| 570 | 19년 전 | 2601 | ||
| 569 | 19년 전 | 3299 | ||
| 568 | 19년 전 | 3525 | ||
| 567 | 19년 전 | 2981 | ||
| 566 | 19년 전 | 2598 | ||
| 565 |
|
19년 전 | 4716 | |
| 564 |
|
19년 전 | 6726 | |
| 563 |
|
19년 전 | 4999 | |
| 562 |
|
19년 전 | 5947 | |
| 561 |
|
19년 전 | 2690 | |
| 560 |
|
19년 전 | 2536 | |
| 559 |
|
19년 전 | 2220 | |
| 558 |
|
19년 전 | 2298 | |
| 557 | 19년 전 | 4593 | ||
| 556 |
|
19년 전 | 4666 | |
| 555 | 19년 전 | 2502 | ||
| 554 | 19년 전 | 2175 | ||
| 553 | 19년 전 | 2522 | ||
| 552 |
|
19년 전 | 3159 | |
| 551 | 19년 전 | 2937 | ||
| 550 |
|
19년 전 | 1895 | |
| 549 |
|
19년 전 | 1955 | |
| 548 |
|
19년 전 | 3142 | |
| 547 |
|
19년 전 | 2356 | |
| 546 |
|
19년 전 | 3612 | |
| 545 |
|
19년 전 | 2543 | |
| 544 |
|
19년 전 | 1847 | |
| 543 |
|
19년 전 | 2453 | |
| 542 |
|
19년 전 | 1726 | |
| 541 |
|
19년 전 | 1404 | |
| 540 |
|
19년 전 | 1532 | |
| 539 |
|
19년 전 | 1801 | |
| 538 |
|
19년 전 | 1581 | |
| 537 |
|
19년 전 | 1778 | |
| 536 |
|
19년 전 | 1560 | |
| 535 |
|
19년 전 | 1958 | |
| 534 |
|
19년 전 | 1843 | |
| 533 |
|
19년 전 | 1445 | |
| 532 |
|
19년 전 | 1442 | |
| 531 |
|
19년 전 | 1355 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기