首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有Typescript的Axios拦截器

带有Typescript的Axios拦截器
EN

Stack Overflow用户
提问于 2019-05-01 17:02:12
回答 2查看 11.3K关注 0票数 1

如何在typescript中正确使用axios的inteceptor:

代码语言:javascript
复制
import axios, { AxiosRequestConfig, AxiosInstance } from 'axios'

HTTP.interceptors.request.use((config: AxiosRequestConfig) => config)

例如,当我创建axios实例时,我设置了默认配置:

代码语言:javascript
复制
const conf: AxiosRequestConfig = {
  baseURL: process.env.VUE_APP_API_URL
}

const HTTP: AxiosInstance = axios.create(conf)

但当我尝试将拦截器与自定义标头一起使用时:

代码语言:javascript
复制
HTTP.interceptors.request.use((config: AxiosRequestConfig) =>{
  headers: {
    'x-projectkey': 1234
  }
})

它不起作用:

代码语言:javascript
复制
Argument of type '(config: AxiosRequestConfig) => void' is not assignable to parameter of type '(value: AxiosRequestConfig) => AxiosRequestConfig | Promise<AxiosRequestConfig>'

我还是个新手,搞不懂这个。

EN

回答 2

Stack Overflow用户

发布于 2019-07-01 12:13:16

你应该返回如下的config:

代码语言:javascript
复制
HTTP.interceptors.request.use((config: AxiosRequestConfig) => {
  config.headers['x-projectkey'] = 1234

  return config
})

玩得开心。

票数 1
EN

Stack Overflow用户

发布于 2019-05-01 17:13:02

从你提到的错误中你丢失了一个返回值。这应该是可行的:

代码语言:javascript
复制
HTTP.interceptors.request.use((config: AxiosRequestConfig) =>({
  headers: {
    'x-projectkey': 1234
  }
}))

或使用return关键字:

代码语言:javascript
复制
HTTP.interceptors.request.use((config: AxiosRequestConfig) =>{
  return {
    headers: {
      'x-projectkey': 1234
    }
  }
})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55933869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档