国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:167日期:2022-06-11 15:14:52
目錄
  • 如何封裝Ajax函數(shù)
  • 封裝自己的 Ajax 函數(shù)

如何封裝Ajax函數(shù)

一個Ajax函數(shù):

// 一個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} 請求方法--method
參數(shù)2:{string} 請求地址--url
參數(shù)3:{object} 請求參數(shù)--params
參數(shù)4:{function} 請求完成后,執(zhí)行的回調(diào)函數(shù)--done

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

  //創(chuàng)建打開一個連接 open
     
  //將對象格式的參數(shù)轉為urlencoded模式
  //新建一個數(shù)組,使用for循環(huán),將對象格式的參數(shù),
  //以(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;
  }
     
//創(chuàng)建打開一個連接
 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);

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

//調(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);
});

以上就是如何封裝一個Ajax函數(shù)的詳細內(nèi)容,更多關于封裝Ajax函數(shù)的資料請關注其它相關文章!

標簽: Ajax
相關文章:
主站蜘蛛池模板: 久久91精品国产91久久小草 | 精品亚洲成a人在线观看 | 九九热精 | 女人国产香蕉久久精品 | 久久99毛片免费观看不卡 | 女人张开腿让男人插 | 欧美不卡一区二区三区 | 亚洲专区在线 | 国产成人综合日韩精品无 | 国产日韩精品一区二区在线观看 | 久久精品香蕉 | 亚洲欧美精品一中文字幕 | 亚洲偷自拍另类图片二区 | 久久w5ww成w人免费不卡 | 国产福利精品在线观看 | 欧美日本综合一区二区三区 | 日本国产免费一区不卡在线 | 日韩三及片 | 99精品在线免费 | 99久久视频 | 欧美黄色免费网站 | 日韩精品免费一级视频 | 亚洲精品国产第一区二区三区 | 国产成人综合洲欧美在线 | a毛片在线看片免费 | 色视频在线观看免费 | 国产精品免费一区二区区 | 久久免费视频7 | 毛片视频网站在线观看 | 成人合集大片bd高清在线观看 | 国产欧美日韩在线一区二区不卡 | 色网址在线| 国产精品揄拍一区二区 | 午夜主播福利视频在线观看 | 直接在线观看的三级网址 | 亚洲国产精品久久久久 | 国产精品自拍第一页 | 亚欧色 | 一级国产精品一级国产精品片 | 奶交性视频欧美 | 久草欧美视频 |