vue3封装axios+Promise及代理配置

本文介绍了如何在Vue3项目中封装axios,并解决跨域问题。通过创建util文件夹,建立http.js来封装axios请求,然后在main.js中引入并挂载到vue原型上。同时,详细讲解了vue.config.js中的devServer.proxy配置,用于本地开发时的接口代理,以避免跨域限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

axios安装

npm install axios

在这里插入图片描述

新建一个util文件夹,用于存放工具类

新建http.js,用于封装axios请求

其中实际开发中,baseURL是设置一个值以便代理的实现,但是需要根据开发/生产环境进行动态配置,防止生产环境打包后斜体样式,访问链接依然带上baseUrl

import axios from 'axios'

const httpUtil = axios.create({
  baseURL: '/api',
  timeout: 100000
})

httpUtil.ajax = (options) => {
  return new Promise((resolve, reject) => {
    httpUtil({
      url: options.url,
      method: options.method,
      data: options.data ? options.data : null,
      params: options.params ? options.params : null
    }).then(res => {
      resolve(res)
    }).catch(err => {
      reject(err.data)
    })
  })
}

export default httpUtil
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值