四步輕松實現(xiàn)ajax發(fā)送異步請求
ajax發(fā)送異步請求,供大家參考,具體內容如下
第一步(得到XMLHttpRequest)
ajax其實只需要學習一個對象:XMLHttpRequest,如果掌握了它,就掌握了ajax!!!
1.得到XMLHttpRequest
大多數(shù)瀏覽器都支持:var xmlHttp=new XMLHttpRequest();
IE6.0:var xmlHttp=new ActiveXObject(“Msxml2.XMLHTTP”);
IE5.0以更早版本的IE:var xmlHttp=new ActiveXObject(“Microsoft.XMLHTTP”);
2.編寫創(chuàng)建XMLHttpRequest對象的函數(shù)
function createXMLHttpRequest(){
try{
return new XMLHttpRequest();
} catch(e){
try{
return new ActiveXObject(“Msxml2.XMLHTTP”);
}catch(e){
try{
return new ActiveXObject(“Microsoft.XMLHTTP”);
}catch(e){
alert(“哥們兒,你用的是什么瀏覽器啊?”);
throw e;
}
}
}
}
第二步(打開與服務器的連接)
xmlHttp.open():用來打開與服務器的連接,它需要三個參數(shù):
請求方式:可以是GET與POST
請求的URL:指定服務器端資源,例如:/day23_1/AServlet
請求是否為異步:如果為true表示發(fā)送異步請求,否則同步請求
xmlHttp.open(“GET”,”/day23_1/AServlet”,true);//比如
第三步(發(fā)送請求)
xmlHttp.send(null):如果不給可能會造成部分瀏覽器無法發(fā)送!
參數(shù):就是請求體內容!如果是GET請求,必須給出null。
如果是POST請求,如下
xmlHttp.send(“username=zhangSan&password=123”);
第四步:
在xmlHttp對象的一個事件上注冊監(jiān)聽器:onreadystatechange
xmlHttp對象一共有5個狀態(tài)
0:初始化未完成狀態(tài),只是創(chuàng)建了XMLHttpRequest對象,還未調用open()方法
1:請求已開始,open()方法已調用,但還沒調用send()方法
2:請求發(fā)送完成狀態(tài),send()方法已調用
3:開始讀取服務器響應
4:讀取服務器響應結束(通常我們只關心最后這個狀態(tài)!!!)
得到xmlHttp對象的狀態(tài)
var state = xmlHttp.readyState;//可能是0、1、2、3、4
得到服務器響應的狀態(tài)碼(200:成功 304:狀態(tài)沒有改變 404 500:服務器錯誤)
var status=xmlHttp.status;//例如200、404、500
得到服務器響應的內容
var content=xmlHttp.responseText;//得到服務器的響應的文本格式的內容(這更通用) var content=xmlHttp.responseXML;//得到服務器的響應的xml響應的內容,它是document對象了!
所以監(jiān)聽器應該這樣寫
xmlHttp.onreadystatechange = function(){
//xmlHttp的5種狀態(tài)都會調用本方法
if(xmlHttp.readyState ==4 && xmlHttp.status == 200){
//雙重判斷:判斷是否為4狀態(tài),而且還要判斷是否為200
var text=xmlHttp.responseText;
}
};
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
ASP小偷程序如何利用XMLHTTP實現(xiàn)表單的提交
ASP小偷程序如何利用XMLHTTP實現(xiàn)表單的提交...2006-07-07
Ajax中responseText返回的是一個頁面而不是一個值
用response返回的內容卻是一個頁面的,可以將String 類型改為void 這樣返回的就不是整個頁面了2014-05-05

