好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 如何封裝一個Ajax函數

如何封裝一個Ajax函數

熱門標簽:提高電話機器人接通率 平涼高德地圖標注商戶要收費嗎 荊州智能電銷機器人 地圖標注與公司業務關系 銷售電銷機器人詐騙 外呼系統api對接 大學校門地圖標注 廣西智能外呼系統多少錢 福建微碼電話機器人

如何封裝Ajax函數

一個Ajax函數:

// 一個Ajax函數
var xhr = null;
if(window.XMLHttpRequest){
   xhr = new XMLHttpRequest;
}else{
   xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
xhr.open("GET","https://jsonplaceholder.typicode.com/users");
xhr.send(null);
xhr.onreadystatechange = function(){
   if(this.readyState === 4){
        console.log(xhr.responseText)
    }
}

封裝自己的 Ajax 函數

參數1:{string} 請求方法--method
參數2:{string} 請求地址--url
參數3:{object} 請求參數--params
參數4:{function} 請求完成后,執行的回調函數--done

 function ajax(method,url,params,done){
//  統一將method方法中的字母轉成大寫,后面判斷GET方法時 就簡單點
  method = method.toUpperCase(); 
  //IE6的兼容
  var xhr = window.XMLHttpRequest
   ? new XMLHttpRequest()
   : new ActiveXObject("Microsoft.XMLHTTP");

  //創建打開一個連接 open
             
  //將對象格式的參數轉為urlencoded模式
  //新建一個數組,使用for循環,將對象格式的參數,
  //以(id = 1)的形式,每一個鍵值對用  符號連接
 var pairs = [];
 for(var k in params){
     pairs.push(k + "=" + params[k]);
  }
  var str = pairs.join("");       
  //判斷是否是get方法 , get方法的話,需要更改url的值
 if(method == "GET"){
       url += "?" + str;
  }
             
//創建打開一個連接
 xhr.open(method,url);

var data = null;
if(method == "POST"){
    //post方法 還需要設置請求頭、請求體
    xhr.setRequestHeader("Content-Type",
    "application/x-www-form-urlencoded");
    data = str;
                 
}
xhr.send(data);

 //執行回調函數
xhr.onreadystatechange = function(){
   if(this.readyState == 4) {
       done(JSON.parse(this.responseText));
   }return;
   // 執行外部傳進來的回調函數即可
   // 需要用到響應體
   }
}  

//調用函數
//get方法
//  ajax("GET","http://localhost:3000/users",
//     {"id":1},
//     function(data){
//         console.log(data);
//  });

//post方法     
ajax("POST", "http://localhost:3000/users",
 { "name": "lucky","class":2,"age":20 },
 function (data) {
     console.log(data);
});

以上就是如何封裝一個Ajax函數的詳細內容,更多關于封裝Ajax函數的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 利用promise及參數解構封裝ajax請求的方法
  • 詳解JavaScript原生封裝ajax請求和Jquery中的ajax請求
  • vue 組件的封裝之基于axios的ajax請求方法
  • 原生js封裝的ajax方法示例
  • 純js封裝的ajax功能函數與用法示例
  • 詳解自定義ajax支持跨域組件封裝
  • react中的ajax封裝實例詳解
  • 基于ajax和jsonp的原生封裝(實例)
  • 使用原生js封裝的ajax實例(兼容jsonp)
  • vue-ajax小封裝實例

標簽:婁底 海南 樂山 內江 德陽 衡陽 黔東 邯鄲

巨人網絡通訊聲明:本文標題《如何封裝一個Ajax函數》,本文關鍵詞  如何,封裝,一個,Ajax,函數,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何封裝一個Ajax函數》相關的同類信息!
  • 本頁收集關于如何封裝一個Ajax函數的相關信息資訊供網民參考!
  • 推薦文章