關於ajax網路請求的封裝執行個體_AJAX相關

來源:互聯網
上載者:User

執行個體代碼:

// 封裝的ajax網路請求函數// obj 是一個對象function AJAX(obj){    //跨域請求    if (obj.dataType == "jsonp") {      //在這裡 callback 必須是全域變數 保證函數消失的時候 這個變數不可以被銷毀      //處理一下函數名(防止多個網路請求 函數名字相同 出現紊亂的情況)      var hehe = "callBack" + "_" + new Date().getTime() + "_" + String(Math.random()).replace(".","");      window[hehe] = obj.success;      //建立 script標籤      var sc = document.createElement("script");      sc.src = obj.url + "?" + "cb=" + hehe;      console.log(sc.src);      document.body.appendChild(sc);      document.body.removeChild(sc);      return;    }  //1、建立 ajax 對象  var ajaxObj = null;  if (window.XMLHttpRequest) {    ajaxObj = new XMLHttpRequest();  }else{    ajaxObj = new ActiveXObject("Microsoft.XMLHTTP");  }  //佈建要求的類型  obj.type = obj.type.toUpperCase() || "GET";  //如果是get請求 並且需要傳遞參數 則需要給 url 後面拼接參數  if (obj.type == "GET") {    var arr = [];//定義數組 用於把Object Storage Service到資料裡面    for (var key in obj.data) {      arr.push(key +"="+ obj.data[key]);    }    //用&分隔數組 讓其轉化為類似:name=lxl&age=18 的形式    var str = arr.join("&");    obj.url = obj.url +"?"+ str;    //撥號    ajaxObj.open(obj.type,obj.url,true);    //發送"name=123&age=18"    ajaxObj.send();  }else{    var arr = [];//定義數組 用於把Object Storage Service到資料裡面    for (var key in obj.data) {      arr.push(key +"="+ obj.data[key]);      //console.log(arr);    }    //用&分隔數組 讓其轉化為類似:name=lxl&age=18 的形式    var str = arr.join("&");    //console.log(str);    ajaxObj.open(obj.type,obj.url,true);    ajaxObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");    ajaxObj.send(str);  }  //監聽  ajaxObj.onreadystatechange = function(){    if (ajaxObj.readyState == 4) {      if (ajaxObj.status >= 200 && ajaxObj.status < 300 || ajaxObj.status == 304) {        //請求成功        obj.success(ajaxObj.responseText);      }else{        //請求失敗        obj.error(ajaxObj.status);      }    }  }}

以上這篇關於ajax網路請求的封裝執行個體就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援雲棲社區。

相關文章

聯繫我們

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