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

主頁 > 知識庫 > Ajax的原生實現關于MIME類型的使用方法

Ajax的原生實現關于MIME類型的使用方法

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

問題描述

下面的例子是一個Ajax的post請求的代碼,這段代碼在測試運行的時候,發現返回的狀態碼為400,服務器不能理解的請求,后來經過查看和修改,發現只需要將下面的代碼稍微改造一下就好了

原代碼

var send = function (url, params, fn) {
  var me = this;
  var xhr = null;
  var data = '';
  fn = fn || function() {};
  params = params || {};
  for(var item in params) {
   data += item + '=' + params[item] + '';
  }
  if(data[data.length - 1] == '') {
   data = data.slice(0, data.length - 1);
  }
  if(window.XMLHttpRequest) {
   xhr = new XMLHttpRequest();
  }else if(window.ActiveXObject) {
   xhr= new ActiveXObject("Microsoft.XMLHTTP");
  }
  xhr.open("post", url, true);
  xhr.setRequestHeader("Content-type", "application/json");
  xhr.onreadystatechange = function () {
   if(xhr.readyState == 4  (xhr.status == 200 || xhr.status == 304)) {
    fn(JSON.parse(xhr.responseText));
   }
  };
  xhr.send(JSON.stringify(params));
}

修改之后的代碼

var send = function (url, params, fn) {
    var me = this;
    var xhr = null;
    fn = fn || function() {};
    params = params || {};
    if(window.XMLHttpRequest) {
      xhr = new XMLHttpRequest();
    }else if(window.ActiveXObject) {
      xhr= new ActiveXObject("Microsoft.XMLHTTP");
    }
    xhr.open("post", url, true);
    xhr.setRequestHeader("Content-type", "application/json");
    xhr.onreadystatechange = function () {
      if(xhr.readyState == 4  (xhr.status == 200 || xhr.status == 304)) {
        fn(JSON.parse(xhr.responseText));
      }
    };
    xhr.send(JSON.stringify(params));
}

這兩段代碼的差別就是,修改之后的代碼去掉了關于data這個變量的處理以及在send中傳遞的參數變為了params這個變量

問題解惑

問題是解決了,但是我心里的疑問卻產生了,之前在使用原生的Ajax的時候,當method為post的時候,傳遞的參數的形式是”name=123age=32”這樣子的,那么為什么現在傳遞一個序列化的JSON對象就可以了呢?

這時候我注意到自己所加的MIME類型,也就是設置Content-type的那處,我設置的是"application/json",這樣看起來就解釋的通了,這時候我回想起之前常用的MIME類型是“application/x-www-form-urlencoded”,這種時候send方法傳遞的參數就要求是”name=123age=32”這樣子的,到這里,解惑完畢啦(~ ̄▽ ̄)~

補充

順便說下405這個狀態碼,上一次見到它的時候,是我前端發送請求的時候,傳遞的參數不對,這次遇到它的時候,是因為后臺還沒有添加這個請求的處理

以上這篇Ajax的原生實現關于MIME類型的使用方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 原生JS簡單實現ajax的方法示例
  • 原生js實現ajax方法(超簡單)

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

巨人網絡通訊聲明:本文標題《Ajax的原生實現關于MIME類型的使用方法》,本文關鍵詞  Ajax,的,原生,實現,關于,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Ajax的原生實現關于MIME類型的使用方法》相關的同類信息!
  • 本頁收集關于Ajax的原生實現關于MIME類型的使用方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 日本精品视频在线| 揉我奶?啊?嗯高潮和尚免费| 男同桌上课时狂揉我下面| 色戒未删减完整版1080p| 美女扒开下面自尽慰视频网站| 日本h在线亚洲网站在线观看| 成人Av乱偷在线AVAV| 精品国产三级国产AⅤ在线观看 | 久久亚洲日本不卡一区二区| 最黄毛片| 欧美午夜电影一区二区三区 | 少妇苏霞肉欲第501章| 调教网| 成人综合在线观看| 国产欧美日韩va另类在线播放| 国产成人啪精品免费app| 欧美乱做爰XXXⅩ久久久小说| 主动打开腿调教男男| 日本工囗邪恶帝全彩大全acg| 欧美h版成版在线观看| 日韩??成人精品无码专区| 国产99视频精品免视看9孕妇| 国产精品欧美亚洲日本久久| 男人强扒女人衣服摸下面 | 爷嗯好大来嘛H共妻| 中国老头和老妇chinese| 波多野结衣啪啪| 日本精品久久久久网站| 美女视频黄频视频大全| 韩国一级一级A片免费观看| 男男日批视频| 少妇无套高潮一二三区| 欧美乱做爰大片免费看A片| 好大好爽好紧小婷视频| 他又娇又软[现代女尊]| 熟女毛多熟妇人妻中出| 国产精品哺乳在线看还在哺乳| 韩日毛片| 性宝福app首页| 国产伦精一区二区18免费| 大乳女被狂揉gif动态图网站|