vue3+ts | axios 二次封装

安装  pnpm i axios

axios 二次封装

// 实用性工具文件 放于 utils文件中
// 对axios函数库进行二次封装?
// 二次封装的目的?利用axios请求、响应拦截器    
 
import axios from 'axios'

// axios.create 创建一个axios实例:可以设置基础路径,超时时间的设置
const request = axios.create({
    baseURL: '/api',    // 请求的基础路径设置
    timeout: 5000       // 超时时间的设置,超出五秒请求是失败的
})

// 请求拦截器
request.interceptors.request.use((config) => {
    // config: 请求拦截器回调注入的对象(配置对象),配置对象的身上最重要的headers属性
    // 可以通过请求头携带公共参数 -token
    return config;
})
// 响应拦截器
request.interceptors.response.use((response)=>{
    return response;        //响应拦截器成功的回调,一般会简化数据
},(error)=>{
    // 失败处理,如 处理http网络错误
    return Promise.reject(new Error(error.message))
});

// 务必对外暴露axios 才可使用 
export default request;

配置代理跨域

vite.config.ts文件中,加入下列代码,配置完重启(重新运行 pnpm run dev)

// 配置代理跨域
  server:{
    proxy: {
      '/api': {
        target: 'http://syt.atguigu.cn',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/,'')
      }
    }
  }

相关推荐

  1. vue3 axios封装

    2024-03-30 06:52:01       63 阅读
  2. 如何封装一个Vue3组件库?

    2024-03-30 06:52:01       50 阅读
  3. vue3基于elementplus 简单实现表格封装

    2024-03-30 06:52:01       30 阅读
  4. vue对axios进行封装

    2024-03-30 06:52:01       48 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-30 06:52:01       91 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-30 06:52:01       97 阅读
  3. 在Django里面运行非项目文件

    2024-03-30 06:52:01       78 阅读
  4. Python语言-面向对象

    2024-03-30 06:52:01       88 阅读

热门阅读

  1. 开源 | 星星充电、特来电和云快充如何赚钱?

    2024-03-30 06:52:01       132 阅读
  2. 常用的SQL术语和概念

    2024-03-30 06:52:01       39 阅读
  3. 简单工厂模式

    2024-03-30 06:52:01       39 阅读
  4. vue 怎么处理get请求,接收url地址栏参数

    2024-03-30 06:52:01       43 阅读
  5. C++ | getopt配置传参

    2024-03-30 06:52:01       40 阅读
  6. Shell脚本开发(六)——函数

    2024-03-30 06:52:01       42 阅读