淺談vue中g(shù)et請求解決傳輸數(shù)據(jù)是數(shù)組格式的問題
qs的stringify接收2個參數(shù),第一個參數(shù)是需要序列化的對象,第二個參數(shù)是轉(zhuǎn)化格式,一般默認(rèn)格式是給出明確的索引,如:arr[0]=1&arr[1]=2
//indices是index的復(fù)數(shù)格式,因此indices是索引的意思 //bracket是括號的意思,因此arrayFormat:'brackets'代表數(shù)組下標(biāo)為空[] qs.stringify({ arr: [1,2,3] }, { indices: false }) //arr=1&arr=2&arr=3 qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'indices' }) //arr[0]=1&arr[1]=2&arr[2]=3 qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'brackets' }) //arr[]=1&arr[]=2&arr[]=3 qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'repeat' }) //arr=1&arr=2&arr=3
qs的parse()使用
如果接口需要獲取get請求接口的請求數(shù)據(jù),可以使用parse(),將拼接在地址的參數(shù)數(shù)據(jù)轉(zhuǎn)換為對象
let url = "111.111.3.203:8080/getList?id=1&name=huahua&arr=a&arr=b" let splitObj = url.split('?')[1] qs.parse(splitObj ) //{ id: '1', name: 'huahua', arr: ['a','b'] }
qs.stringify和JSON.stringify的區(qū)別
let obj = { a: 1, b: 2 } qs.stringify(obj) //a=1&b=2 JSON.stringify(obj) // "{'a': 1, 'b': 2}"
qs解決數(shù)組參數(shù)問題
安裝axios,qs
npm install qs
npm install axios -S
在main.js中引入qs
import Vue from 'vue' import qs from 'qs' import axios from 'axios' Vue.prototype.$qs = qs; //qs全局掛載在vue實例上 Vue.prototype.$http = axios; //axios全局掛載在vue實例上
在組件中使用
get請求的請求參數(shù)是將數(shù)據(jù)放在config的params中,實際是通過“&”拼接在url上
如果請求參數(shù)是數(shù)組arr=[1,2,3],get請求不對數(shù)組做任何處理,則傳遞給后端的接口是
"url地址?arr[]=1&arr[]=2&arr[]=3",接口會報錯,因為識別不了“[]”這個符號
需要對數(shù)組進(jìn)行修改,需要通過qs的stringify()方法將數(shù)組序列化,則傳遞給后端的接口是 “url地址?arr=1&arr=2&arr=3”,接口不會報錯
this.arr = [1,2,3] //寫法一,直接使用qs的stringify() this.$http.get('url地址', { params: { arr: this.$qs.stringify(this.arr) //數(shù)組拼接在url地址 url地址?arr=1&arr=2&arr=3 } }).then(() => { }) //寫法二 ,使用axios提供的paramsSerializer序列化函數(shù) this.$http.get('url地址', { params: { arr: this.arr //數(shù)組拼接在url地址 url地址?arr=1&arr=2&arr=3 }, paramsSerializer: (params) => { return this.$qs.stringify(params) } }).then(() => { })
以上這篇淺談vue中g(shù)et請求解決傳輸數(shù)據(jù)是數(shù)組格式的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式
- Vue.js+HighCharts實現(xiàn)動態(tài)請求展示時序數(shù)據(jù)
- vue本地模擬服務(wù)器請求mock數(shù)據(jù)的方法詳解
- vue異步請求數(shù)據(jù)重新渲染方式
- VUE前端從后臺請求過來的數(shù)據(jù)進(jìn)行轉(zhuǎn)換數(shù)據(jù)結(jié)構(gòu)操作
- vue項目中axios的封裝請求
- vue3實戰(zhàn)教程之a(chǎn)xios的封裝和環(huán)境變量
- Vue3中使用typescript封裝axios的實例詳解
- vue中數(shù)據(jù)請求axios的封裝和使用
相關(guān)文章
Vue中如何點(diǎn)擊獲取當(dāng)前元素下標(biāo)
這篇文章主要介紹了Vue中如何點(diǎn)擊獲取當(dāng)前元素下標(biāo)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05深入理解Vue響應(yīng)式原理及其實現(xiàn)方式
Vue的響應(yīng)式原理是Vue最核心的特性之一,也是Vue能夠為開發(fā)者提供高效便捷的開發(fā)體驗的重要原因之一,這篇文章主要介紹了響應(yīng)式的原理及其實現(xiàn)方式,需要詳細(xì)了解可以參考下文2023-05-05Vue瀏覽器鏈接與接口參數(shù)實現(xiàn)加密過程詳解
這篇文章主要介紹了Vue瀏覽器鏈接與接口參數(shù)實現(xiàn)加密過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12vue2+element-ui+nodejs實現(xiàn)圖片上傳和修改圖片到數(shù)據(jù)庫的方法
在Web開發(fā)中經(jīng)常需要使用圖片,有時候需要對圖片進(jìn)行上傳,這篇文章主要給大家介紹了關(guān)于vue2+element-ui+nodejs實現(xiàn)圖片上傳和修改圖片到數(shù)據(jù)庫的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04vue中v-cloak解決刷新或者加載出現(xiàn)閃爍問題(顯示變量)
這篇文章主要介紹了vue中v-cloak解決刷新或者加載出現(xiàn)閃爍問題(顯示變量) ,需要的朋友可以參考下2018-04-04