vue 封装axios请求
时间: 2023-08-21 21:04:55 浏览: 176
在Vue中封装axios请求可以通过以下步骤实现:
1. 创建一个`request.js`文件来封装axios。在这个文件中,你可以将axios的各种配置项进行设置,比如设置baseURL、设置请求拦截器和响应拦截器等。这样,调用`request.js`相当于调用axios,并且还可以添加一些额外的配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [Vue对Axios网络请求进行封装](https://blog.csdn.net/qq_47188967/article/details/129447379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
相关问题
vue封装axios请求
在Vue中使用axios进行网络请求是非常常见的。我们可以对axios进行封装来方便地在Vue中使用。这里提供一个例子,包括axios的安装、请求拦截器、设置请求超时时间以及post请求头的设置。
首先,我们需要安装axios,可以通过npm install axios命令来进行安装。后,我们可以在Vue项目中的main.js文件中引入axios,并且将其挂载到Vue原型上,这样在组件中就可以通过this.$http来进行访问。接下来,我们可以封装一个request函数,封装axios的请求拦截器、设置请求超时时间以及post请求头的设置。
下面是一个简单的封装axios请求的例子:
1. 安装axios
```
npm install axios
```
2. 在main.js中引入axios并挂载到Vue原型上
```
import axios from 'axios'
Vue.prototype.$http = axios
```
3. 封装request函数
```
import axios from 'axios'
import store from '@/store/index'
// 创建axios实例
const service = axios.create({
timeout: 10000 // 请求超时时间
})
// 请求拦截器
service.interceptors.request.use(
config => {
// 每次发送请求之前判断vuex中是否存在token
// 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况
// 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断
const token = store.state.token
token && (config.headers.Authorization = token)
return config
},
error => {
return Promise.error(error)
}
)
// 响应拦截器
service.interceptors.response.use(
response => {
// 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据
// 否则的话抛出错误
if (response.status === 200) {
return Promise.resolve(response.data)
} else {
return Promise.reject(response)
}
},
error => {
// 服务器返回不是 2 开头的情况,会进入这个回调
// 可以根据后台返回的状态码进行不同的操作
if (error.response.status) {
switch (error.response.status) {
// 401: 未登录
// 未登录则跳转登录页面,并携带当前页面的路径
// 在登录成功后返回当前页面,这一步需要在登录页操作。
case 401:
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
})
break
// 403 token过期
// 登录过期对用户进行提示
// 清除本地token和清空vuex中token对象
// 跳转登录页面
case 403:
Toast({
message: '登录过期,请重新登录',
duration: 1000,
forbidClick: true
})
// 清除token
localStorage.removeItem('token')
store.commit('loginSuccess', null)
// 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面
setTimeout(() => {
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
})
}, 1000)
break
// 404请求不存在
case 404:
Toast({
message: '网络请求不存在',
duration: 1500,
forbidClick: true
})
break
// 其他错误,直接抛出错误提示
default:
Toast({
message: error.response.data.message,
duration: 1500,
forbidClick: true
})
}
return Promise.reject(error.response)
}
}
)
export default service
```
4. 在组件中使用request函数
```
import request from '@/utils/request'
// 发送get请求
request.get(url, params).then(res => {
console.log(res)
}).catch(err => {
console.log(err)
})
// 发送post请求
request.post(url, data).then(res => {
console.log(res)
}).catch(err => {
console.log(err)
})
```
--相关问题--:
VUE封装 axios 请求
在 Vue.js 开发中,封装 Axios 请求是一种常见的做法,通常是为了简化全局的 API 调用,避免在每个组件中都重复引入 Axios 并设置相同的配置。以下是创建一个简单的 Axios 封装实例:
```javascript
import axios from 'axios';
import { MessageBox } from 'element-ui';
// 创建一个 Vue 插件
export default {
install(Vue) {
// 创建一个 Vue 实例的方法
Vue.prototype.$axios = axios.create({
baseURL: process.env.BASE_API, // 当前应用的基础URL
timeout: 5000, // 设置默认超时时间
headers: {
'Content-Type': 'application/json', // 默认请求头
},
});
// 添加全局错误处理
Vue.prototype.$httpError = (error) => {
if (error.response) {
console.log(error.response.data);
MessageBox.error(error.response.data.message || error.response.status);
} else {
console.error('未知错误', error);
}
};
// 错误拦截器
Vue.prototype.$axios.interceptors.response.use(
response => response,
error => {
this.$httpError(error);
return Promise.reject(error);
}
);
// 请求拦截器
Vue.prototype.$axios.interceptors.request.use(
config => {
// 在发送请求之前做些什么
return config;
},
error => {
// 对请求错误做些什么
this.$httpError(error);
return Promise.reject(error);
}
);
},
};
```
通过这种方式,你在 Vue 组件中就可以像下面这样轻松地发送请求了:
```vue
methods: {
fetchData() {
this.$axios.get('/api/data').then(response => {
// 处理成功响应
}).catch(this.$httpError);
}
}
```
阅读全文