javascript中ajax請求方式(GET與POST)狀態值說明

來源:互聯網
上載者:User

 注意:XMLHttpRequest 是 AJAX 的基礎,在建立 XMLHttpRequest 對象時,必須與你寫的ajax方法在同一個‘<script></script>’標籤中!否則ajax請求會出錯,並無法返回資料。 javascript/js的ajax的POST/GET請求。

 javascript/js的ajax的POST請求:

 代碼如下 複製代碼

<script type="text/javascript">
/* 建立 XMLHttpRequest 對象 */
var xmlHttp;
function GetXmlHttpObject(){
    if (window.XMLHttpRequest){
      // code for IE7+, Firefox, Chrome, Opera, Safari
      xmlhttp=new XMLHttpRequest();
    }else{// code for IE6, IE5
      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    return xmlhttp;
}
// -----------ajax方法-----------//
function getLabelsPost(){
    xmlHttp=GetXmlHttpObject();
    if (xmlHttp==null){
        alert('您的瀏覽器不支援AJAX!');
        return;
    }
    var url="http://www.111cn.net /t/"+Math.random();
    xmlhttp.open("POST",url,true);
    xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xmlhttp.send();
    xmlHttp.onreadystatechange=getLabelsOK;//發送事件後,收到資訊了調用函數
}
function getOkPost(){
    if(xmlHttp.readyState==1||xmlHttp.readyState==2||xmlHttp.readyState==3){
        // 本地提示:載入中/處理中
                                                 
    }
    if (xmlHttp.readyState==4 && xmlHttp.status==200){
        var d=xmlHttp.responseText; // 傳回值
        // 處理傳回值
    }
}
</script>

javascript/js的ajax的GET請求:

 代碼如下 複製代碼

<script type="text/javascript">
/* 建立 XMLHttpRequest 對象 */
var xmlHttp;
function GetXmlHttpObject(){
    if (window.XMLHttpRequest){
      // code for IE7+, Firefox, Chrome, Opera, Safari
      xmlhttp=new XMLHttpRequest();
    }else{// code for IE6, IE5
      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    return xmlhttp;
}
// -----------ajax方法-----------//
function getLabelsGet(){
    xmlHttp=GetXmlHttpObject();
    if (xmlHttp==null){
        alert('您的瀏覽器不支援AJAX!');
        return;
    }
    var id = document.getElementById('id').value;
    var url="http://www.lifefrom.com?id="+id+"&t/"+Math.random();
    xmlHttp.open("GET",url,true);
    xmlHttp.onreadystatechange=favorOK;//發送事件後,收到資訊了調用函數
    xmlHttp.send();
}
                   
function getOkGet(){
    if(xmlHttp.readyState==1||xmlHttp.readyState==2||xmlHttp.readyState==3){
        // 本地提示:載入中
                         
    }
    if (xmlHttp.readyState==4 && xmlHttp.status==200){
        var d= xmlHttp.responseText;
        // 處理返回結果
                           
    }
}
</script>

readyState屬性

包括五種可能的取值:

  0: (未初始化)send方法還沒有被調用

  1: (載入中)已調用了send方法,請求還在處理

  2: (已載入)send方法已完成,整個應答已接收

  3: (互動中) 正在解析應答

  4: (已完成) 應答已經解析,準備好進行下一步處理。

對象XMLHttpRequest

屬性status的含義:

  0**:未被始化

  1**:請求收到,繼續處理

  2**:操作成功收到,分析、接受

  3**:完成此請求必須進一步處理

  4**:請求包含一個錯誤文法或不能完成

  5**:伺服器執行一個完全有效請求失敗

  100——客戶必須繼續發出請求(Continue)

  101——客戶要求伺服器根據請求轉換HTTP協議版本(Switching protocols)

  200——交易成功(OK)

  201——提示知道新檔案的URL(Created)

  202——接受和處理、但處理未完成(Accepted)

  203——返回資訊不確定或不完整(Non-Authoritative Information)

  204——請求收到,但返回資訊為空白(No Content)

  205——伺服器完成了請求,使用者代理程式必須複位當前已經瀏覽過的檔案(Reset Content)

  206——伺服器已經完成了部分使用者的GET請求(Partial Content)

  300——請求的資源可在多處得到(Mult<a href="http://ip.111cn.net/">ip</a>le Choices)

  301——刪除請求資料(Moved Permanently)

  302——在其他地址發現了請求資料(Found)

  303——建議客戶訪問其他URL或訪問方式(See Other)

  304——用戶端已經執行了GET,但檔案未變化(Not Modified)

  305——請求的資源必須從伺服器指定的地址得到(Use Proxy)

  306——前一版本HTTP中使用的代碼,現行版本中不再使用

  307——申明請求的資源臨時性刪除(Temporary Redirect)

  400——錯誤請求,如語法錯誤(Bad Request)

  401——請求授權失敗(Unauthorized)

  402——保留有效ChargeTo頭響應(Payment Required)

  403——請求不允許(由於伺服器上檔案或目錄的使用權限設定導致資源不可用)(Forbidden)

  404——沒有發現檔案、查詢或URl(沒有找到指定的資源)(Not Found)

  405——使用者在Request-Line欄位定義的方法不允許(Method Not Allowed)

  406——根據使用者發送的Accept拖,請求資源不可訪問(Not Acceptable) 

  407——類似401,使用者必須首先在Proxy 伺服器上得到授權(Proxy Authentication Required)

  408——用戶端沒有在使用者指定的餓時間內完成請求(Request Timeout)

  409——對當前資源狀態,請求不能完成(Conflict)

  410——伺服器上不再有此資源且無進一步的參考地址(Gone)

  411——伺服器拒絕使用者定義的Content-Length屬性請求(Length Required)

  412——一個或多個要求標頭欄位在當前請求中錯誤(Precondition Failed)

  413——請求的資源大於伺服器允許的大小(Request Entity Too Large)

  414——請求的資源URL長於伺服器允許的長度(Request-URI Too Long)

  415——請求資源不支援要求項目格式(Unsupported Media Type)

  416——請求中包含Range要求標頭欄位,在當前請求資源範圍內沒有range指示值,請求也不包含If-Range要求標頭欄位(Requested Range Not Suitable)  

  417——伺服器不滿足請求Expect頭欄位指定的期望值,如果是Proxy 伺服器,可能是下一級伺服器不能滿足請求(Expectation Failed)<br />  

  500——伺服器產生內部錯誤(Internal Server Error)

  501——伺服器不支援要求的函數(Not Implemented)

  502——伺服器暫時不可用,有時是為了防止發生系統過載(Bad Gateway)

  503——伺服器過載或暫停維修(Service Unavailable)

  504——關口過載,伺服器使用另一個關口或服務來響應使用者,等待時間設定值較長(Gateway Timeout)

  505——伺服器不支援或拒絕支要求標頭中指定的HTTP版本(HTTP Version Not Supported )

  12029——an unknown error occurred while processing the request on the server. the status code returned from the server was : 12029(原因:網路不通. 重新整理一下就知道了)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.