欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

axios中post請(qǐng)求json和application/x-www-form-urlencoded詳解

 更新時(shí)間:2022年10月20日 09:40:40   作者:牧羊狼  
Axios是專注于網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求的庫(kù),相比于原生的XMLHttpRequest對(duì)象,axios簡(jiǎn)單易用,下面這篇文章主要給大家介紹了關(guān)于axios中post請(qǐng)求json和application/x-www-form-urlencoded的相關(guān)資料,需要的朋友可以參考下

前言

前端向后端傳輸數(shù)據(jù)時(shí),如果是get傳輸,直接傳在url后;如果是post傳輸,則在請(qǐng)求體body中傳輸。

在body中的數(shù)據(jù)格式又有兩種,一種是  json  數(shù)據(jù)格式,另一種是 字符串。具體要用哪種格式取決于后端入?yún)⒌母袷健?/p>

如果后端接收json數(shù)據(jù)類型,post 的 headers 需要設(shè)置 { ‘content-type’: ’application/json’ },傳給后端的數(shù)據(jù)就形如  { ‘name’:’edward’, ‘age’:’25’ } 

如果后端接收的是(表單)字符串類型,post 的 headers 需設(shè)置  { ‘content-type’: ’application/x-www-form-urlencoded’ },

,傳輸給后端的數(shù)據(jù)就形如   ‘name=edward&age=25’  

qs   

qs.stringfy() 將對(duì)象序列化成URL的形式

axios默認(rèn)數(shù)據(jù)格式為json,所以:

1.當(dāng)后端需要接收json格式的數(shù)據(jù)時(shí),post請(qǐng)求頭不需要設(shè)置請(qǐng)求頭,數(shù)據(jù)格式也不需要我們?nèi)マD(zhuǎn)換(若數(shù)據(jù)已經(jīng)是json);

2.當(dāng)后端需要接收字符串格式的數(shù)據(jù)時(shí),我們需要給post請(qǐng)求頭設(shè)置{ ‘content-type’: ’application/x-www-form-urlencoded’ },

   這個(gè)時(shí)候如果我們傳的入?yún)⑹且粋€(gè) js 對(duì)象,這時(shí)候我們就需要用 qs 轉(zhuǎn)換數(shù)據(jù)格式,qs具體用法如下:

 安裝模塊:npm  i  qs  -S

import qs from 'qs';
const data = { name:'edward' , age:'25'};  // 我們傳的是 js 對(duì)象
const options = {
  method: 'POST',
  headers: { 'content-type': 'application/x-www-form-urlencoded' },
  data: qs.stringify(data),   // 用 qs 將js對(duì)象轉(zhuǎn)換為字符串 'name=edward&age=25'
  url: 'http://www.edward.com'
}; axios(options);

我們也可以在封裝axios的時(shí)候,給它全局設(shè)置qs 

axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

【區(qū)分】: JSON.stringfy()  和 qs.stringfy() 

  let  data = { name: 'edward', age: '25' }

  前者:JSON.stringfy(data)  //  ”{ 'name' : 'edward' , 'age' : '25' }”

  后者:qs.stringfy(data)  // 'name=edward&age=25'

【區(qū)分】:jQuery 中 $.ajax 的post請(qǐng)求  VS   axios的post 請(qǐng)求的 content-type 默認(rèn)值

  前者:"application/x-www-form-urlencoded"

  后者:"application/json"

$.ajax({
   type: 'POST',
   contentType: 'application/json;charset=utf-8', // 發(fā)送的數(shù)據(jù)類型
   dataType: 'json',   // 接收的數(shù)據(jù)類型
   url: 'http://www.edward.com',
   data: JSON.stringfy(formData),
   success: function (res) {
      console.log(res.data)
   }
}) 

contentType: 告訴服務(wù)器,我要發(fā)什么類型的數(shù)據(jù)

dataType:告訴服務(wù)器,我要想什么類型的數(shù)據(jù),如果沒有指定,那么會(huì)自動(dòng)推斷是返回 XML,還是JSON,還是script,還是String。

注意 :$.ajax() post發(fā)送到服務(wù)器的數(shù)據(jù)。

將自動(dòng)轉(zhuǎn)換為請(qǐng)求字符串格式。

如果為對(duì)象,如 { name: 'edward', age: '25' },jQuery 將自動(dòng)轉(zhuǎn)化為 'name=edward&age=25'

如果為數(shù)組,jQuery 將自動(dòng)為不同值對(duì)應(yīng)同一個(gè)名稱。如 {foo:["bar1", "bar2"]} 轉(zhuǎn)換為 '&foo=bar1&foo=bar2'。

總結(jié)

到此這篇關(guān)于axios中post請(qǐng)求json和application/x-www-form-urlencoded詳解的文章就介紹到這了,更多相關(guān)axios post請(qǐng)求json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Vue適時(shí)清理keepalive緩存方案

    詳解Vue適時(shí)清理keepalive緩存方案

    說到Vue緩存,我們肯定首先選擇官方提供的緩存方案keep-alive,本文主要介紹了詳解Vue適時(shí)清理keepalive緩存方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能

    詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能

    這篇文章主要介紹了vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 深入解析el-col-group強(qiáng)大且靈活的Element表格列組件

    深入解析el-col-group強(qiáng)大且靈活的Element表格列組件

    這篇文章主要為大家介紹了el-col-group強(qiáng)大且靈活的Element表格列組件深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • vue項(xiàng)目實(shí)現(xiàn)下載zip壓縮包

    vue項(xiàng)目實(shí)現(xiàn)下載zip壓縮包

    這篇文章主要介紹了vue項(xiàng)目實(shí)現(xiàn)下載zip壓縮包方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 基于el-tree實(shí)現(xiàn)懶加載穿梭條的示例代碼

    基于el-tree實(shí)現(xiàn)懶加載穿梭條的示例代碼

    這篇文章主要介紹了基于el-tree實(shí)現(xiàn)懶加載穿梭條的示例代碼,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Ant?Design?Vue?走馬燈實(shí)現(xiàn)單頁(yè)多張圖片輪播效果

    Ant?Design?Vue?走馬燈實(shí)現(xiàn)單頁(yè)多張圖片輪播效果

    這篇文章主要介紹了Ant?Design?Vue?走馬燈實(shí)現(xiàn)單頁(yè)多張圖片輪播,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • vue封裝axios與api接口管理的完整步驟

    vue封裝axios與api接口管理的完整步驟

    在實(shí)際的項(xiàng)目中,和后臺(tái)的數(shù)據(jù)交互是少不了的,我通常使用的是 axios 庫(kù),所以下面這篇文章主要給大家介紹了關(guān)于vue封裝axios與api接口管理的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • element編輯表單el-radio回顯之后無法選擇的問題解決

    element編輯表單el-radio回顯之后無法選擇的問題解決

    今天主要來談一下element-ui編輯表單中的el-radio回顯之后無法選擇的問題,主要涉及到vue的雙向綁定,以及element-ui編輯表單中的el-radio的默認(rèn)類型,感興趣的可以了解一下
    2021-08-08
  • vue-router項(xiàng)目實(shí)戰(zhàn)總結(jié)篇

    vue-router項(xiàng)目實(shí)戰(zhàn)總結(jié)篇

    vue-router 是 Vue.js 官方的路由庫(kù).這篇文章主要介紹了vue-router項(xiàng)目實(shí)戰(zhàn)總結(jié),需要的朋友可以參考下
    2018-02-02
  • 詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問題及解決辦法

    詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問題及解決辦法

    這篇文章主要介紹了詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問題及解決辦法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03

最新評(píng)論