axios get传递数组 paramsSerializer序列化

//---封装的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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值