vue3使用ts配置响应拦截器
时间: 2023-11-26 17:05:25 浏览: 79
要在Vue 3中使用TypeScript配置响应拦截器,你需要进行以下步骤:
1. 首先,确保已经安装了axios和@types/axios库。可以使用以下命令进行安装:
```
npm install axios @types/axios
```
2. 在你的Vue项目中创建一个拦截器文件,比如 `interceptors.ts`。在这个文件中,你可以定义请求和响应的拦截器逻辑。
```typescript
import axios, { AxiosInstance } from 'axios';
// 创建一个Axios实例
const instance: AxiosInstance = axios.create({
baseURL: 'https://api.example.com', // 设置你的API基本URL
timeout: 5000, // 设置请求超时时间
});
// 请求拦截器
instance.interceptors.request.use(
(config) => {
// 在发送请求之前做一些处理,比如添加请求头
config.headers.common['Authorization'] = 'Bearer token';
return config;
},
(error) => {
// 处理请求错误
return Promise.reject(error);
}
);
// 响应拦截器
instance.interceptors.response.use(
(response) => {
// 在接收响应数据之前做一些处理,比如解析响应数据
return response.data;
},
(error) => {
// 处理响应错误
return Promise.reject(error);
}
);
export default instance;
```
3. 在你的Vue组件中使用拦截器。你可以在需要发送HTTP请求的地方导入 `interceptors.ts` 文件并使用创建的Axios实例进行请求。
```typescript
import axiosInstance from './interceptors';
// 使用拦截器发送请求
axiosInstance.get('/api/data')
.then((response) => {
console.log(response);
})
.catch((error) => {
console.error(error);
});
```
这样,你就可以在Vue 3中使用TypeScript配置响应拦截器了。记得根据你的实际需求修改拦截器逻辑。
阅读全文