首先是一個建立AJAX的函數:
複製代碼 代碼如下:
var http_request=null;
function create_ajax(){
http_request = false;
//開始初始化XMLHttpRequest對象
if(window.XMLHttpRequest) { //Mozilla 瀏覽器
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {//設定MiME類別
http_request.overrideMimeType('text/xml');
}
}
else if (window.ActiveXObject) { // IE瀏覽器
try {
http_request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
http_request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
if (!http_request) { // 異常,建立對象執行個體失敗
window.alert("不能建立XMLHttpRequest對象執行個體.");
return false;
}
}
然後是調用這個函數來處理AJAX
複製代碼 代碼如下:
var obj1;
function get_ajax(url,obj) {//初始化、指定處理函數、發送請求的函數
obj1=obj;
create_ajax();
http_request.onreadystatechange =processobj; // 確定發送請求的方式和URL以及是否同步執行下段代碼
http_request.open("POST", url, true);
http_request.send(null);
}
function processobj(){
document.getElementById(obj1).innerHTML="Loading...";
if (http_request.readyState == 4) { // 判斷對象狀態
if (http_request.status == 200) { // 資訊已經成功返回,開始處理資訊
document.getElementById(obj1).innerHTML=http_request.responseText;
} else { //頁面不正常
document.getElementById(obj1).innerHTML="loading error.";
}
}
}
以上就是AJAX的主體,再在你需要用AJAX的頁面把這段Javascript包含進去,就可以方便的調用了:
複製代碼 代碼如下:
<script type="text/javascript" src="ajax.js" src="ajax.js" ></script>
Welcome.
<div id="d1" onclick="get_ajax('ajax/get1.jsp','d1');">d1</div>
<div id="d2" onclick="get_ajax('ajax/get2.jsp','d2');">d2</div>
<div id="a">d2</div>
'ajax/get1.jsp'和'ajax/get2.jsp',是兩個後台擷取資料的頁面,這樣,一點擊d1,get1.jsp就會被動態載入進來,非常方便,當然這隻是一個最基本的功能的模型,還可以在上面加上很多功能,大家自由發揮吧。