這次帶給大家只需四步驟即可實現ajax發送非同步請求,四步實現ajax發送非同步請求的注意事項有哪些,以下就是實戰案例,一起來看一下。
ajax發送非同步請求,供大家參考,具體內容如下
第一步(得到XMLHttpRequest)
ajax其實只需要學習一個對象:XMLHttpRequest,如果掌握了它,就掌握了ajax!!!
##1.得到XMLHttpRequest大多數瀏覽器都支援:var xmlHttp=new XMLHttpRequest();IE6 .0:var xmlHttp=new ActiveXObject(“Msxml2.XMLHTTP”);
IE5.0以更早版本的IE:var xmlHttp=new ActiveXObject(“Microsoft.XMLHTTP”);
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():用來開啟與伺服器的連線,它需要三個參數: 請求方式:可以是GET與POST請求的URL:指定伺服器端資源,例如:/day23_1/A
Servlet請求是否為非同步:如果為true表示發送非同步請求,否則同步請求
xmlHttp.open(“GET”,”/day23_1/AServlet”,true);//例如
第三步驟(傳送請求)
xmlHttp.send(null):如果沒有給予可能會造成部分瀏覽器無法傳送! 參數:就是請求體內容!如果是GET請求,必須給null。 如果是
POST請求,如下
#xmlHttp.send(“username=zhangSan&password=123”);
第四個步驟:
在xmlHttp物件的一個事件上註冊監聽器:onreadystatechangexmlHttp物件一共有5個狀態
1:請求已開始,open()方法已呼叫,但還沒呼叫send()方法
2:請求傳送完成狀態,send()方法已調用
3:開始讀取伺服器回應
4:讀取伺服器回應結束(通常我們只關心最後這個狀態!!!)
var state = xmlHttp.readyState;//可能是0、1、2、3、4
狀態碼(200:成功304:狀態沒有改變404 500:伺服器錯誤)
var status=xmlHttp.status;//例如200、404、500
var content=xmlHttp.responseText;//得到服务器的响应的文本格式的内容(这更通用) var content=xmlHttp.responseXML;//得到服务器的响应的xml响应的内容,它是document对象了!
xmlHttp.onreadystatechange = function(){ //xmlHttp的5种状态都会调用本方法 if(xmlHttp.readyState ==4 && xmlHttp.status == 200){ //双重判断:判断是否为4状态,而且还要判断是否为200 var text=xmlHttp.responseText; } };
以上是只需四步驟即可實現ajax發送非同步請求的詳細內容。更多資訊請關注PHP中文網其他相關文章!