vue中g(shù)et請(qǐng)求如何傳遞數(shù)組參數(shù)的方法示例
前言: vue中在與后端進(jìn)行數(shù)據(jù)交互時(shí),使用axios發(fā)送請(qǐng)求,不做配置直接使用get請(qǐng)求傳遞數(shù)組類型參數(shù)的時(shí)候,后端是無(wú)法接收數(shù)據(jù)的,需要對(duì)axios一些簡(jiǎn)單的配置才能讓后端完美的接收數(shù)組
1、問(wèn)題
示例代碼
let params = {
statusList: ['OVERDUE', 'DELAY']
}
this.$http.get('/list', params)
.then(res => {})
.catch(e => {})
上述代碼在不做配置的時(shí)候請(qǐng)求信息為:/list?statusList[]=OVERDUE&statusList[]=DELAY對(duì)于后端來(lái)說(shuō),statusList[]形式的提交是無(wú)效的,實(shí)際需要的是/list?statusList=OVERDUE&statusList=DELAY這種方式的提交。那么我們應(yīng)該如何來(lái)解決這種問(wèn)題呢?
2、解決方案
2.1 qs插件
qs主要是增加一些安全性的查詢字符串解析和序列化字符串的庫(kù),qs的更多使用方式可以參考總結(jié)中提供的地址學(xué)習(xí)
1、qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'indices' })
// 輸出結(jié)果:'a[0]=b&a[1]=c'
2、qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'brackets' })
// 輸出結(jié)果:'a[]=b&a[]=c'
3、qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'repeat' })
// 輸出結(jié)果:'a=b&a=c'
4、qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'comma' })
// 輸出結(jié)果:'a=b,c'
上述我們列舉了qs中的序列化幾種配置,其中{ arrayFormat: 'repeat' }的序列化結(jié)果滿足我們的條件
2.2 axios配置
axios中有一個(gè)專門(mén)對(duì)數(shù)據(jù)進(jìn)行序列化的配置屬性paramsSerializer
paramsSerializer: function(params) {
return Qs.stringify(params, {arrayFormat: 'repeat'})
},
2.3 具體配置
我們可以在axios請(qǐng)求攔截器中對(duì)參數(shù)進(jìn)行序列化配置
axios.interceptors.request.use(async (config) => {
//只針對(duì)get方式進(jìn)行序列化
if (config.method === 'get') {
config.paramsSerializer = function(params) {
return qs.stringify(params, { arrayFormat: 'repeat' })
}
}
}
3、總結(jié)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue-router(this.$router)如何在新窗口打開(kāi)路由跳轉(zhuǎn)頁(yè)面
這篇文章主要介紹了vue-router(this.$router)如何在新窗口打開(kāi)路由跳轉(zhuǎn)頁(yè)面問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
vue使用nprogress實(shí)現(xiàn)進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了vue使用nprogress實(shí)現(xiàn)進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
django使用channels2.x實(shí)現(xiàn)實(shí)時(shí)通訊
這篇文章主要介紹了django使用channels2.x實(shí)現(xiàn)實(shí)時(shí)通訊,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Ant Design Vue table中列超長(zhǎng)顯示...并加提示語(yǔ)的實(shí)例
這篇文章主要介紹了Ant Design Vue table中列超長(zhǎng)顯示...并加提示語(yǔ)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
Vue3使用hook封裝媒體查詢和事件監(jiān)聽(tīng)的代碼示例
這篇文章主要給大家詳細(xì)介紹Vue3如何使用hook封裝媒體查詢和事件監(jiān)聽(tīng),使得Vue的開(kāi)發(fā)更加絲滑,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),感興趣的同學(xué)跟著小編一起來(lái)學(xué)習(xí)吧2023-07-07
Vue.js中computed屬性高效的數(shù)據(jù)處理案例
computed是Vue中一個(gè)計(jì)算屬性,它可以根據(jù)依賴的數(shù)據(jù)動(dòng)態(tài)計(jì)算出一個(gè)新的值,并將其緩存起來(lái),這篇文章主要給大家介紹了關(guān)于Vue.js中computed屬性高效的數(shù)據(jù)處理的相關(guān)資料,需要的朋友可以參考下2024-09-09
element el-input directive數(shù)字進(jìn)行控制
本文介紹了vue使用directive 進(jìn)行控制的方法,使用element開(kāi)發(fā)的過(guò)程中遇到循環(huán)的數(shù)據(jù)只能輸入數(shù)字,并且有不要小數(shù)點(diǎn),有需要小數(shù)點(diǎn)的,就有一定的參考價(jià)值,有興趣的可以了解一下2018-10-10

