AJAX 隨記
更新時間:2009年06月01日 00:57:57 作者:
使用AJAX可以提供無頁面刷新便可以從后臺更新頁面數(shù)據(jù),因此可以做出類似桌面應(yīng)用的效果,但是每用一次AJAX便會用到大量的Javascript語句,今天我把整理了一下,使它變得結(jié)構(gòu)化一些。
首先是一個創(chuàng)建AJAX的函數(shù):
var http_request=null;
function create_ajax(){
http_request = false;
//開始初始化XMLHttpRequest對象
if(window.XMLHttpRequest) { //Mozilla 瀏覽器
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {//設(shè)置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) { // 異常,創(chuàng)建對象實例失敗
window.alert("不能創(chuàng)建XMLHttpRequest對象實例.");
return false;
}
}
然后是調(diào)用這個函數(shù)來處理AJAX
var obj1;
function get_ajax(url,obj) {//初始化、指定處理函數(shù)、發(fā)送請求的函數(shù)
obj1=obj;
create_ajax();
http_request.onreadystatechange =processobj; // 確定發(fā)送請求的方式和URL以及是否同步執(zhí)行下段代碼
http_request.open("POST", url, true);
http_request.send(null);
}
function processobj(){
document.getElementById(obj1).innerHTML="Loading...";
if (http_request.readyState == 4) { // 判斷對象狀態(tài)
if (http_request.status == 200) { // 信息已經(jīng)成功返回,開始處理信息
document.getElementById(obj1).innerHTML=http_request.responseText;
} else { //頁面不正常
document.getElementById(obj1).innerHTML="loading error.";
}
}
}
以上就是AJAX的主體,再在你需要用AJAX的頁面把這段Javascript包含進去,就可以方便的調(diào)用了:
<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',是兩個后臺獲取數(shù)據(jù)的頁面,這樣,一點擊d1,get1.jsp就會被動態(tài)的加載進來,非常方便,當(dāng)然這只是一個最基本的功能的模型,還可以在上面加上很多功能,大家自由發(fā)揮吧。
復(fù)制代碼 代碼如下:
var http_request=null;
function create_ajax(){
http_request = false;
//開始初始化XMLHttpRequest對象
if(window.XMLHttpRequest) { //Mozilla 瀏覽器
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {//設(shè)置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) { // 異常,創(chuàng)建對象實例失敗
window.alert("不能創(chuàng)建XMLHttpRequest對象實例.");
return false;
}
}
然后是調(diào)用這個函數(shù)來處理AJAX
復(fù)制代碼 代碼如下:
var obj1;
function get_ajax(url,obj) {//初始化、指定處理函數(shù)、發(fā)送請求的函數(shù)
obj1=obj;
create_ajax();
http_request.onreadystatechange =processobj; // 確定發(fā)送請求的方式和URL以及是否同步執(zhí)行下段代碼
http_request.open("POST", url, true);
http_request.send(null);
}
function processobj(){
document.getElementById(obj1).innerHTML="Loading...";
if (http_request.readyState == 4) { // 判斷對象狀態(tài)
if (http_request.status == 200) { // 信息已經(jīng)成功返回,開始處理信息
document.getElementById(obj1).innerHTML=http_request.responseText;
} else { //頁面不正常
document.getElementById(obj1).innerHTML="loading error.";
}
}
}
以上就是AJAX的主體,再在你需要用AJAX的頁面把這段Javascript包含進去,就可以方便的調(diào)用了:
復(fù)制代碼 代碼如下:
<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',是兩個后臺獲取數(shù)據(jù)的頁面,這樣,一點擊d1,get1.jsp就會被動態(tài)的加載進來,非常方便,當(dāng)然這只是一個最基本的功能的模型,還可以在上面加上很多功能,大家自由發(fā)揮吧。
相關(guān)文章
ajax異步傳值及后端接收參數(shù)的多種方式小結(jié)
這篇文章主要介紹了ajax異步傳值及后端接收參數(shù)的多種方式小結(jié),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11JQuery ajax返回JSON時的處理方式 (三種方式)
json數(shù)據(jù)是一種經(jīng)型的實時數(shù)據(jù)交互的數(shù)據(jù)存儲方法,使用到最多的應(yīng)該是ajax與json配合使用了,下面由腳本之家小編給大家分享JQuery ajax返回JSON時的處理方式 (三種方式),需要的朋友可以參考下2015-09-09jQuery+Ajax+PHP實現(xiàn)“喜歡”評級功能附源碼下載
有同學(xué)問我如何實現(xiàn)一個像美麗說那樣的“我喜歡”評級功能,當(dāng)用戶看到自己喜歡的圖片或文章時,點擊“紅心”按鈕,系統(tǒng)會自動記錄用戶的點擊,并將總數(shù)加1。這樣再結(jié)合不同的系統(tǒng),可以將此功能應(yīng)用到投票或收藏商品中去(如淘寶的收藏商品)。2015-10-10jQuery ajax中使用serialize()方法提交表單數(shù)據(jù)示例
使用jQuery ajax的serialize() 方法表單序列化為鍵值對(key1=value1&key2=value2…)后提交,下面是使用serialize()序列化表單的實例,感興趣的朋友可以參考下2013-10-10