用axios封装一个拦截器
时间: 2023-10-25 12:20:48 浏览: 97
好的,我可以帮您封装一个axios拦截器。您可以先安装axios依赖,然后编写如下代码:
```js
import axios from 'axios';
// 创建axios实例
const instance = axios.create({
baseURL: 'https://www.example.com/api/v1', // api的base_url
timeout: 5000 // 请求超时时间
});
// 设置请求拦截器
instance.interceptors.request.use(config => {
// 在发送请求前做些什么,比如添加token
const token = localStorage.getItem('token');
if (token) {
config.headers.Authorization = `Bearer ${token}`;
}
return config;
}, error => {
// 对请求错误做些什么
console.error(error);
return Promise.reject(error);
});
// 设置响应拦截器
instance.interceptors.response.use(response => {
// 对响应数据做点什么
return response.data;
}, error => {
// 对响应错误做点什么
console.error(error);
return Promise.reject(error);
});
export default instance;
```
这样,您就可以使用封装好的axios实例来发送请求了,拦截器会在请求发送前添加token,以及在响应后对数据进行处理。
阅读全文