關(guān)于axios配置請(qǐng)求頭content-type實(shí)例詳解
前言
現(xiàn)在網(wǎng)上可能發(fā)送Ajax請(qǐng)求有很多種插件,每種用法可能略有差異,大家只需挑選一種自己喜歡的即可。畢竟現(xiàn)在還有很多人使用jQuery,$.ajax用法也是很多了。
axios配置請(qǐng)求頭content-type方法如下:
axios 是Ajax的一個(gè)插件,axios雖然是一個(gè)插件,但是我們不需要通過Vue.use(axios)來使用,下載完成后,只需在項(xiàng)目中引入即可。(一般我們放在了請(qǐng)求接口的公共文件中引用)
npm install axios -S
axios 發(fā)送post請(qǐng)求時(shí)默認(rèn)是直接把 json 放到請(qǐng)求體中提交到后端的,axios默認(rèn)的請(qǐng)求頭content-type類型是’application/json;charset=utf-8’.
content-type的三種常見數(shù)據(jù)格式:
// 1 默認(rèn)的格式請(qǐng)求體中的數(shù)據(jù)會(huì)以json字符串的形式發(fā)送到后端 'Content-Type: application/json ' // 2 請(qǐng)求體中的數(shù)據(jù)會(huì)以普通表單形式(鍵值對(duì))發(fā)送到后端 'Content-Type: application/x-www-form-urlencoded' // 3 它會(huì)將請(qǐng)求體的數(shù)據(jù)處理為一條消息,以標(biāo)簽為單元,用分隔符分開。既可以上傳鍵值對(duì),也可以上傳文件 'Content-Type: multipart/form-data'
Content-Type: application/json這種參數(shù)是默認(rèn)的就不說了
若后端需要接受的數(shù)據(jù)類型為:application/x-www-form-urlencoded,我們前端該如何配置:
1 用 URLSearchParams 傳遞參數(shù)
var param = new URLSearchParams()
param.append('name',name)
param.append('age' , age)
axios(
{
method:'post',
url: url,
data : param,
}
).then(res => res).catch(err => err)
2 配置axios請(qǐng)求頭中的content-type為指定類型(這個(gè)比較常用)
axios.defaults.headers["Content-Type"] = "application/x-www-form-urlencoded";
3 引入 qs ,這個(gè)庫是 axios 里面包含的,不需要再下載了
import Qs from 'qs'
let params= {
"name": "ll",
"age": "18"
}
axios({
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
},
method: 'post',
url: url,
data: Qs.stringify(params)
})
若后端需要接受的數(shù)據(jù)類型為:Content-Type: multipart/form-data,我們前端該如何配置:
應(yīng)用場(chǎng)景:對(duì)于這種類型的數(shù)據(jù),我們常見前端頁面上傳個(gè)人圖像,然后點(diǎn)擊保存發(fā)送后端修改原始數(shù)據(jù)
let params = new FormData()
params.append('file', this.file)
params.append('qq', this.qq)
params.append('weChat', this.WeChat)
axios.post(URL, params, {headers: {'Content-Type': 'multipart/form-data'}}).then(res => {
if (res.data.code === 0) {
this.$router.go(-1)
}
}).catch(error => {
alert('更新用戶數(shù)據(jù)失敗' + error)
})
補(bǔ)充:axios 根據(jù)接口設(shè)置不同的content-type
問題呢是這樣的,我們前端再請(qǐng)求后端接口的時(shí)候,通常content-type的格式就是application/json,但是也有的時(shí)候后端需要我們傳的格式為form表單的格式application/x-www-form-urlencoded; charset=UTF-8。
具體操作,我的運(yùn)行環(huán)境為,uniapp
首先,axios請(qǐng)求攔截

其中config里面有我們傳的參數(shù),可以自行打印查看一下,
其中 config.data.need是我自己定義的字段,來判斷content-type的具體格式是哪一種。

就是 我們?cè)傩枰袷綖閍pplication/x-www-form-urlencoded; charset=UTF-8的接口里面?zhèn)魅?need:true就好了
總結(jié)
到此這篇關(guān)于axios配置請(qǐng)求頭content-typ的文章就介紹到這了,更多相關(guān)axios配置請(qǐng)求頭content-type內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue封裝遠(yuǎn)程下拉框組件的實(shí)現(xiàn)示例
本文主要介紹了Vue封裝遠(yuǎn)程下拉框組件的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
vue如何在style標(biāo)簽中使用變量(數(shù)據(jù))詳解
在我們編寫css樣式中是不能直接使用vue data中的變量的,下面這篇文章主要給大家介紹了關(guān)于vue如何在style標(biāo)簽中使用變量(數(shù)據(jù))的相關(guān)資料,需要的朋友可以參考下2022-09-09
從0到1搭建element后臺(tái)框架優(yōu)化篇(打包優(yōu)化)
這篇文章主要介紹了從0到1搭建element后臺(tái)框架優(yōu)化篇(打包優(yōu)化),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05
vue-cli 默認(rèn)路由再子路由選中下的選中狀態(tài)問題及解決代碼
這篇文章主要介紹了vue-cli 默認(rèn)路由再子路由選中下的選中狀態(tài)問題及解決代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
解讀計(jì)算屬性和watch監(jiān)聽的區(qū)別及說明
計(jì)算屬性是基于它們的依賴進(jìn)行緩存的,只有在它的相關(guān)依賴發(fā)生改變時(shí)才會(huì)重新求值,而watch則是一個(gè)更為通用的監(jiān)聽器,它可以在數(shù)據(jù)變化時(shí)執(zhí)行異步操作或開銷較大的操作2025-01-01
解決父組件將子組件作為彈窗調(diào)用只執(zhí)行一次created的問題
這篇文章主要介紹了解決父組件將子組件作為彈窗調(diào)用只執(zhí)行一次created的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
Element-plus封裝搜索組件的實(shí)現(xiàn)
在后臺(tái)管理系統(tǒng)中,經(jīng)常需要在多個(gè)頁面中使用搜索功能,本文就來介紹一下Element-plus封裝搜索組件的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-08-08
Vue實(shí)現(xiàn)移動(dòng)端左右滑動(dòng)效果的方法
最近得到一個(gè)新需求,需要在Vue項(xiàng)目的移動(dòng)端頁面上加上左右滑動(dòng)效果,經(jīng)過一番折騰,最終決定四月vue-touch。下面小編把實(shí)現(xiàn)代碼分享給大家,感興趣的朋友一起看看吧2018-11-11

