濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法

Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法

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

問題描述

下面的例子是一個(gè)Ajax的post請(qǐng)求的代碼,這段代碼在測(cè)試運(yùn)行的時(shí)候,發(fā)現(xiàn)返回的狀態(tài)碼為400,服務(wù)器不能理解的請(qǐng)求,后來(lái)經(jīng)過查看和修改,發(fā)現(xiàn)只需要將下面的代碼稍微改造一下就好了

原代碼

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));
}

這兩段代碼的差別就是,修改之后的代碼去掉了關(guān)于data這個(gè)變量的處理以及在send中傳遞的參數(shù)變?yōu)榱藀arams這個(gè)變量

問題解惑

問題是解決了,但是我心里的疑問卻產(chǎn)生了,之前在使用原生的Ajax的時(shí)候,當(dāng)method為post的時(shí)候,傳遞的參數(shù)的形式是”name=123age=32”這樣子的,那么為什么現(xiàn)在傳遞一個(gè)序列化的JSON對(duì)象就可以了呢?

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

補(bǔ)充

順便說下405這個(gè)狀態(tài)碼,上一次見到它的時(shí)候,是我前端發(fā)送請(qǐng)求的時(shí)候,傳遞的參數(shù)不對(duì),這次遇到它的時(shí)候,是因?yàn)楹笈_(tái)還沒有添加這個(gè)請(qǐng)求的處理

以上這篇Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 原生JS簡(jiǎn)單實(shí)現(xiàn)ajax的方法示例
  • 原生js實(shí)現(xiàn)ajax方法(超簡(jiǎn)單)

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法》,本文關(guān)鍵詞  Ajax,的,原生,實(shí)現(xiàn),關(guān)于,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Ajax的原生實(shí)現(xiàn)關(guān)于MIME類型的使用方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    佛山市| 福建省| 新竹县| 扶风县| 喀喇| 枝江市| 石门县| 太康县| 共和县| 信丰县| 定结县| 富阳市| 县级市| 灌阳县| 常宁市| 哈密市| 印江| 阜阳市| 宁陕县| 安西县| 驻马店市| 平顶山市| 余干县| 扎囊县| 厦门市| 若尔盖县| 凤山市| 沐川县| 洪泽县| 宁强县| 滦南县| 汉中市| 察隅县| 阜新市| 廉江市| 贵阳市| 南和县| 张家口市| 安岳县| 康定县| 凭祥市|