//---封装的axios 中 Httpconfig/htpp.js
import axios from 'axios'
import qs from 'qs'
// 创建axios实例
const service = axios.create({
baseURL: process.env.BASE_API, // api的base_url
timeout:90000 // 请求超时时间
})
// request拦截器
service.interceptors.request.use(config => {
console.log('config',config)
if (config.isgetArray) { //要使自定义的isgetArray有效则需要在axios依赖下的lib/core/mergeConfig中添加白名单 防止被过滤掉
config.paramsSerializer = function (params) {
return qs.stringify(params, {arrayFormat: 'repeat'}) 形式: ids=1&ids=2&ids=3
// 4种不同形式
//1.qs.stringify({ids: [1, 2, 3]}, { indices: false }) --形式: ids=1&ids=2&ids=3
//2.qs.stringify({ids: [1, 2, 3]}, {arrayFormat: ‘indices‘}) --形式: ids[0]=1&ids[1]=2&ids[2]=3
//3.qs.stringify({ids: [1, 2, 3]}, {arrayFormat: ‘brackets‘}) --形式:ids[]=1&ids[]=2&ids[]=3
//4.qs.stringify({ids: [1, 2, 3]}, {arrayFormat: ‘repeat‘}) --形式: ids=1&ids=2&ids=3
}
}
return config
}, error => {
Message({
message: error,
type: 'error',
})
Promise.reject(error)
})
//---使用的 api中
import request from '@/Httpconfig/http'
export function getApi(params) {
return request({
url: '/user/getApi.do',
method: 'put',
data: params,
isgetArray: true,
})
}
用法: getApi(order_id: [1, 2, 3]) //-- http:xxx/user/getApi?order_id=1&order_id=2&order_id=3
axios get传递数组 paramsSerializer序列化
最新推荐文章于 2023-07-20 17:08:31 发布