var AJAX = {
XmlHttp: null,
create: function () {
try {
if (window.XMLHttpRequest) {
AJAX.XmlHttp = new XMLHttpRequest();
// 일부의 모질라 버전을은 readyState property,
// onreadystate event를 지원하지 않으므로. - from xmlextrs
if (this.XmlHttp.readyState == null) {
this.XmlHttp.readyState = 1;
this.XmlHttp.addEventListener("load", function () {
this.XmlHttp.readyState = 4;
if (typeof this.XmlHttp.onreadystatechange == "function")
tmpXmlHtp.onreadystatechange();
}, false);
}
} else {
AJAX.XmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
}
catch (e) {
alert("Your browser does not support XmlHttp objects");
//throw new Error("Your browser does not support XmlHttp objects");
}
}
}
AJAX.openXML = function (method, url, async, uname, pswd) {
if (AJAX.XmlHttp != null) {
if (uname == undefined) {
AJAX.XmlHttp.open(method, url, async, uname, pswd);
} else {
AJAX.XmlHttp.open(method, url, async);
}
AJAX.XmlHttp.onreadystatechange = function () {
if (AJAX.XmlHttp.readyState == 4) {
if (AJAX.XmlHttp.status == 200) {
// 200 은 HTTP에서 성공 i.e) 404 : not found
AJAX.statusSuccessHandler(AJAX.XmlHttp.responseXML.xml);
} else {
AJAX.statusErrorHandler();
alert('Error while loading!');
}
}
}
} else {
alert ("need to create xmlhttp object");
}
}
AJAX.openText = function (method, url, async, uname, pswd) {
if (AJAX.XmlHttp != null) {
if (uname == undefined) {
AJAX.XmlHttp.open(method, url, async, uname, pswd);
} else {
AJAX.XmlHttp.open(method, url, async);
}
AJAX.XmlHttp.onreadystatechange = function () {
if (AJAX.XmlHttp.readyState == 4) {
if (AJAX.XmlHttp.status == 200) {
// 200 은 HTTP에서 성공 i.e) 404 : not found
AJAX.statusSuccessHandler(AJAX.XmlHttp.responseText);
} else {
AJAX.statusErrorHandler();
alert('Error while loading!');
}
}
}
} else {
alert ("need to create xmlhttp object");
}
}
AJAX.send = function (content) {
if (content == undefined)
AJAX.XmlHttp.send(null);
else
AJAX.XmlHttp.send(content);
}
AJAX.setOnReadyStateChange = function (funcname) {
if (AJAX.XmlHttp) {
AJAX.XmlHttp.onreadystatechange = funcname;
} else {
alert ("need to create xmlhttp object");
}
}
// status 200 일 때 처리 함수
AJAX.statusSuccessHandler = function (data) {
alert(data);
}
AJAX.setStatusSuccessHandler = function (funcname) {
AJAX.statusSuccessHandler = funcname;
}
// status 200 일 때 기본 처리 함수
// setStatusSuccessHandler() 로 대체 가능
AJAX.statusErrorHandler = function (status) {
AJAX.rtnText = AJAX.XmlHttp.responseText;
}
AJAX.setStatusSuccessHandler = function (funcname) {
AJAX.statusSuccessHandler = funcname
}
AJAX.setStatusErrorHandler = function (funcname) {
AJAX.statusErrorHandler = funcname
}
AJAX.setRequestHeader = function (label, value)
{
AJAX.XmlHttp.setRequestHeader(label, value);
}
// 사용법
// AJAX.create();
// AJAX.openText('GET','jsontest.php', true);
// AJAX.setStatusSuccessHandler(proc);
// AJAX.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
// AJAX.send("test=테스트");
//
// function proc(abc)
// {
// document.getElementById('test').innerHTML = abc;
// }
출처 :
http://www.oraclejava.co.kr/zboard/view.php?id=php&page=1&sn1=&divpage=1&sn=off&ss=on&sc=on&select_arrange=headnum
&desc=asc&no=39
2006/02/25
동적 웹페이지를 위한 기본 AJAX 클래스 코드
가장 많이 본 글
-
IIS는 IIS 관리자 외에,. 다양한 도구를 통해서 매니지먼트가 가능합니다. 다음은 프로그래밍 기반 관리툴의 종류 및 장,단점 입니다. 다음 내용은 물론, 프로그래밍이 가능한 관리자에게 유용할 꺼라 생각됩니다. 1. 커맨드라인 명령어. ...
-
W3SVC를 다시 시작하지 못했습니다. 오류 코드: 0x8007041d
-
Windows Server 2008 의 Hyper-V 나 그전에 Virtural Server & PC 가 있지만 역시 현재 까지는 가상화 툴의 단연 VMware 이죠.. 그리고 여러가지 목적에서 많이 사용되고 있고..^^ VMware 에서 OS...
댓글 없음:
댓글 쓰기