ajax發送非同步請求的四個步驟

來源:互聯網
上載者:User
本文主要教大家輕鬆實現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”);

2.編寫建立XMLHttpRequest對象的函數

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/AServlet
請求是否為非同步:如果為true表示發送非同步請求,否則同步請求

xmlHttp.open(“GET”,”/day23_1/AServlet”,true);//比如

第三步(發送請求)

xmlHttp.send(null):如果不給可能會造成部分瀏覽器無法發送!

參數:就是請求體內容!如果是GET請求,必須給出null。
如果是POST請求,如下

xmlHttp.send(“username=zhangSan&password=123”);

第四步:

在xmlHttp對象的一個事件上註冊監聽器:onreadystatechange
xmlHttp對象一共有5個狀態

0:初始化未完成狀態,只是建立了XMLHttpRequest對象,還未調用open()方法
1:請求已開始,open()方法已調用,但還沒調用send()方法
2:請求發送完成狀態,send()方法已調用
3:開始讀取伺服器響應
4:讀取伺服器響應結束(通常我們只關心最後這個狀態!!!)

得到xmlHttp對象的狀態

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;     } };

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.