axios.interceptors.request 支持config自定义参数的方法及注意事项

1.在请求头里自定义参数

//----http.js里
service.interceptors.request.use(config => {
    console.log('config',config)
     //    查看发送请求的接口有没有设置isLoading
     if(config.headers.isLoading !== false){
        startLoading();//请求时的加载动画
       }
    return config
}, error => {
    Message({
        message: error,
        type: 'error',
    })
    Promise.reject(error)
})

//----封装的api 中
export function getApi (params) {
  return request({
    url: '/user/getApi.do',
    method: 'get',
    params,
    headers:{ isLoading:true}
  })
}

2.直接在config中自定义参数

//---http.js里
service.interceptors.request.use(config => {
    console.log('config',config)
    if (config.isgetArray) {
    //(数组序列化问题见 文章 --axios get传递数组 paramsSerializer序列化)
        config.paramsSerializer = function (params) {
            return qs.stringify(params, {arrayFormat: 'repeat'}) 形式: ids=1&ids=2&id=3
        }
    }
    if (config.isUpdateUser) { //要使自定义的isUpdateUser有效则需要在axios依赖下的lib/core/mergeConfig中添加白名单 防止被过滤掉
        if (sessionStorage.getItem('updateUserToken')) {
            config.headers.common['Authorization'] = sessionStorage.getItem('updateUserToken')
        }
    }
    return config
}, error => {
    Message({
        message: error,
        type: 'error',
    })
    Promise.reject(error)
})```

//----封装的api 中
export function getApi (params) {
    return request({
        url: '/user/getApi.do',
        method: 'put',
        data: params,
        isUpdateUser: true,
    })
}

注意
**因为axios对传入的参数做了过滤处理,我们需要在过滤白名单数组中增加我们需要的字段(axios/lib/core/mergeConfig.js中),否则config对象里找不到isgetArray,isUpdateUser
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值