【web】3、封装axios

1、安装axios

pnpm install axios

2、封装

在开发项目的时候避免不了与后端进行交互,因此我们需要使用axios插件实现发送网络请求。在开发项目的时候

我们经常会把axios进行二次封装。

目的:

1:使用请求拦截器,可以在请求拦截器中处理一些业务(开始进度条、请求头携带公共参数)

2:使用响应拦截器,可以在响应拦截器中处理一些业务(进度条结束、简化服务器返回的数据、处理http网络错误)

在根目录下创建utils/request.ts

import axios from 'axios';
import { ElMessage } from 'element-plus';
//创建axios实例
let request = axios.create({
  'baseURL': import.meta.env.VITE_APP_BASE_API,
  'timeout': 5000
})
//请求拦截器

request.interceptors.request.use(config => {
  return config;
});
//响应拦截器
request.interceptors.response.use((response) => {
  return response.data;
}, (error) => {
  //处理网络错误
  let msg = '',
    status = error.response.status;

  switch (status) {
  case 401:
    msg = 'token过期';
    break;
  case 403:
    msg = '无权访问';
    break;
  case 404:
    msg = '请求地址错误';
    break;
  case 500:
    msg = '服务器出现问题';
    break;
  default:
    msg = '无网络';

  }
  ElMessage({
    'type': 'error',
    'message': msg
  })
  return Promise.reject(error);
});
export default request;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lxtx-0510

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值