成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

原生js如何實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求-創(chuàng)新互聯(lián)

小編給大家分享一下原生js如何實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司專注于岳陽(yáng)樓企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),商城網(wǎng)站建設(shè)。岳陽(yáng)樓網(wǎng)站建設(shè)公司,為岳陽(yáng)樓等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站策劃,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)

直接上代碼:

const ajax = (params = {}) => {
 const nowJson = params.jsonp ? jsonp(params) : json(params);
 function jsonp(params){
  //創(chuàng)建script標(biāo)簽并加入到頁(yè)面中
  var callbackName = params.jsonp;
  var head = document.getElementsByTagName('head')[0];
  // 設(shè)置傳遞給后臺(tái)的回調(diào)參數(shù)名
  params.data['callback'] = callbackName;
  var data = formatParams(params.data);
  var script = document.createElement('script');
  head.appendChild(script);
 
  window[callbackName] = function(jsonData) {
   head.removeChild(script);
   clearTimeout(script.timer);
   window[callbackName] = null;
   params.success && params.success(jsonData);
  };
  //console.log(window[callbackName])
  //console.log(params.url + '?' + data)
 
  //url形式傳參
  //說(shuō)明:下面的script加載資源后會(huì)返回一個(gè)自執(zhí)行函數(shù):[callbackName](responseData),這個(gè)形式就是去執(zhí)行一個(gè)函數(shù),函數(shù)的名字是一個(gè)參數(shù)
  //      同時(shí)在windows對(duì)象上定義了這個(gè)函數(shù):[callbackName] = function(responseData){},這時(shí)就會(huì)調(diào)用這個(gè)函數(shù)
  script.src = params.url + '?' + data;
 
  //為了得知此次請(qǐng)求是否成功,設(shè)置超時(shí)處理
  if(params.time) {
   script.timer = setTimeout(function() {
    window[callbackName] = null;
    head.removeChild(script);
    params.error && params.error({
     message: '超時(shí)'
    });
   }, params.time);
  }
 }
 //格式化參數(shù)
 function formatParams(data) {
  var arr = [];
  for(var name in data) {
   arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[name]));
  };
 
  // 添加一個(gè)隨機(jī)數(shù),防止緩存
  arr.push('v=' + random());
  return arr.join('&');
 }
 
 // 獲取隨機(jī)數(shù)
 function random() {
  return Math.floor(Math.random() * 10000 + 500);
 }
 function json(params) {
  // 請(qǐng)求方式,默認(rèn)是GET
  params.type = (params.type || 'GET').toUpperCase();
  // 避免有特殊字符,必須格式化傳輸數(shù)據(jù)
  params.data = formatParams(params.data);
  var xhr = null;
 
  // 實(shí)例化XMLHttpRequest對(duì)象
  if(window.XMLHttpRequest) {
   xhr = new XMLHttpRequest();
  } else {
   // IE6及其以下版本
   xhr = new ActiveXObjcet('Microsoft.XMLHTTP');
  };
 
  // 監(jiān)聽(tīng)事件,只要 readyState 的值變化,就會(huì)調(diào)用 readystatechange 事件
  xhr.onreadystatechange = function() {
   // readyState屬性表示請(qǐng)求/響應(yīng)過(guò)程的當(dāng)前活動(dòng)階段,4為完成,已經(jīng)接收到全部響應(yīng)數(shù)據(jù)
   if(xhr.readyState == 4) {
    var status = xhr.status;
    // status:響應(yīng)的HTTP狀態(tài)碼,以2開(kāi)頭的都是成功
    if(status >= 200 && status < 300) {
     var response = '';
     // 判斷接受數(shù)據(jù)的內(nèi)容類型
     var type = xhr.getResponseHeader('Content-type');
     if(type.indexOf('xml') !== -1 && xhr.responseXML) {
      response = xhr.responseXML; //Document對(duì)象響應(yīng)
     } else if(type === 'application/json') {
      response = JSON.parse(xhr.responseText); //JSON響應(yīng)
     } else {
      response = xhr.responseText; //字符串響應(yīng)
     };
     // 成功回調(diào)函數(shù)
     params.success && params.success(response);
    } else {
     params.error && params.error(status);
    }
   };
  };
 
  // 連接和傳輸數(shù)據(jù)
  if(params.type == 'GET') {
   // 三個(gè)參數(shù):請(qǐng)求方式、請(qǐng)求地址(get方式時(shí),傳輸數(shù)據(jù)是加在地址后的)、是否異步請(qǐng)求(同步請(qǐng)求的情況極少);
   xhr.open(params.type, params.url + '?' + params.data, true);
   xhr.send(null);
  } else {
   xhr.open(params.type, params.url, true);
   //必須,設(shè)置提交時(shí)的內(nèi)容類型
   xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
   // 傳輸數(shù)據(jù)
   xhr.send(params.data);
  }
 }
}
export default ajax;

調(diào)用:

ajax({
   jsonp:'JSONP',
   url:'http://localhost:8080/test',
   data:{},
   time:1000,
   success:function(data){
    console.log(data)
   },
   error:function(error){
    console.log(error)
   }
  })

以上是“原生js如何實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標(biāo)題名稱:原生js如何實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求-創(chuàng)新互聯(lián)
分享鏈接:http://jinyejixie.com/article16/jshgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名小程序開(kāi)發(fā)、標(biāo)簽優(yōu)化面包屑導(dǎo)航、App開(kāi)發(fā)自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司
瓦房店市| 昭苏县| 文成县| 天镇县| 方山县| 吉林省| 天镇县| 商洛市| 岑巩县| 汨罗市| 霍林郭勒市| 沂南县| 屏东市| 大余县| 高雄市| 福安市| 高雄县| 崇阳县| 克拉玛依市| 建始县| 堆龙德庆县| 淮北市| 宜君县| 安西县| 杭锦后旗| 内乡县| 万源市| 普定县| 塘沽区| 旌德县| 衡阳县| 余江县| 全椒县| 秀山| 巴楚县| 洪江市| 名山县| 赣州市| 疏勒县| 凌云县| 常山县|