首頁 > web前端 > js教程 > 主體

實作ajax發送非同步請求(圖文教學)

亚连
發布: 2018-05-21 17:18:59
原創
1401 人瀏覽過

這篇文章主要教大家輕鬆實現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;
     } 
};
登入後複製

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

ajax實作上傳圖片儲存到後台並讀取的實例(圖文教學)

Struts2和Ajax資料互動(圖文教學)

Ajax請求發送成功但不進success的解決方法(圖文教學)

#

以上是實作ajax發送非同步請求(圖文教學)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!