婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 如何封裝一個(gè)Ajax函數(shù)

如何封裝一個(gè)Ajax函數(shù)

熱門標(biāo)簽:提高電話機(jī)器人接通率 平?jīng)龈叩碌貓D標(biāo)注商戶要收費(fèi)嗎 荊州智能電銷機(jī)器人 地圖標(biāo)注與公司業(yè)務(wù)關(guān)系 銷售電銷機(jī)器人詐騙 外呼系統(tǒng)api對(duì)接 大學(xué)校門地圖標(biāo)注 廣西智能外呼系統(tǒng)多少錢 福建微碼電話機(jī)器人

如何封裝Ajax函數(shù)

一個(gè)Ajax函數(shù):

// 一個(gè)Ajax函數(shù)
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 函數(shù)

參數(shù)1:{string} 請(qǐng)求方法--method
參數(shù)2:{string} 請(qǐng)求地址--url
參數(shù)3:{object} 請(qǐng)求參數(shù)--params
參數(shù)4:{function} 請(qǐng)求完成后,執(zhí)行的回調(diào)函數(shù)--done

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

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

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

 //執(zhí)行回調(diào)函數(shù)
xhr.onreadystatechange = function(){
   if(this.readyState == 4) {
       done(JSON.parse(this.responseText));
   }return;
   // 執(zhí)行外部傳進(jìn)來的回調(diào)函數(shù)即可
   // 需要用到響應(yīng)體
   }
}  

//調(diào)用函數(shù)
//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);
});

以上就是如何封裝一個(gè)Ajax函數(shù)的詳細(xì)內(nèi)容,更多關(guān)于封裝Ajax函數(shù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

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

標(biāo)簽:婁底 海南 樂山 內(nèi)江 德陽(yáng) 衡陽(yáng) 黔東 邯鄲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何封裝一個(gè)Ajax函數(shù)》,本文關(guān)鍵詞  如何,封裝,一個(gè),Ajax,函數(shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何封裝一個(gè)Ajax函數(shù)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于如何封裝一個(gè)Ajax函數(shù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 昆山市| 会东县| 西乌珠穆沁旗| 礼泉县| 陇川县| 临邑县| 阳西县| 静海县| 云梦县| 克山县| 娄烦县| 上高县| 定结县| 新密市| 镇巴县| 大田县| 隆安县| 象山县| 井冈山市| 龙山县| 清新县| 枣庄市| 张北县| 沁源县| 龙胜| 邵阳县| 含山县| 正定县| 修武县| 通化市| 交城县| 清新县| 准格尔旗| 高清| 白银市| 祁东县| 灵璧县| 宁化县| 济宁市| 洮南市| 东丽区|