VUE封装axios调用

一、Vue项目配置代理、axios封装和接口调用的实现方案

  1. 首先在项目根目录创建 vue.config.js 配置代理:
module.exports = {
  devServer: {
    proxy: {
      '/api': {  // 代理所有以/api开头的请求
        target: 'http://your-api-domain.com', // 你的后端接口地址
        changeOrigin: true, // 允许跨域
        pathRewrite: {
          '^/api': '' // 路径重写(去掉/api前缀)
        }
      }
    }
  }
}
  1. 创建 src/utils/request.js 文件(axios封装):
import axios from 'axios'
import { Message } from 'element-ui' // 按需引入UI组件库的提示组件
import router from '@/router'

// 创建axios实例
const service = axios.create({
  baseURL: process.env.NODE_ENV === 'development' ? '/api' : process.env.VUE_APP_BASE_API, // 根据环境切换
  timeout: 10000 // 请求超时时间
})

// 请求拦截器
service.interceptors.request.use(
  config => {
    // 在发送请求之前做些什么(例如添加token)
    const token = localStorage.getItem('token')
    if (token) {
      config.headers['Authorization'] = `Bearer ${token}`
    }
    return config
  },
  error => {
    // 对请求错误做些什么
    return Promise.reject(error)
  }
)

// 响应拦截器
service.interceptors.response.use(
  response => {
    // 对响应数据做处理(例如只返回data部分)
    const res = response.data
    
    // 这里根据你的后端接口协议进行修改
    if (res.code !== 200) {
      Message.error(res.message || 'Error')
      return Promise.reject(new Error(res.message || 'Error'))
    }
    
    return res
  },
  error => {
    // 对响应错误做处理
    if (error.response) {
      switch (error.response.status) {
        case 401:
          Message.error('登录过期,请重新登录')
          router.push('/login')
          break
        case 403:
          Message.error('拒绝访问')
          break
        case 500:
          Message.error('服务器错误')
          break
        default:
          Message.error(error.response.data.message || '请求错误')
      }
    } else {
      Message.error('网络连接失败')
    }
    return Promise.reject(error)
  }
)

export default service
  1. 创建接口封装文件 src/api/user.js:
import request from '@/utils/request'

// 用户登录
export function login(data) {
  return request({
    url: '/user/login',
    method: 'post',
    data
  })
}

// 获取用户信息
export function getUserInfo(data) {
  return request({
    url: '/user/info',
    method: 'get',
    params: data
  })
}

// 其他接口...
  1. 在组件中使用封装好的接口:
<template>
  <div>
    <button @click="handleLogin">登录</button>
  </div>
</template>

<script>
import { login, getUserInfo } from '@/api/user'

export default {
  methods: {
    async handleLogin() {
      try {
        // 调用登录接口
        const loginRes = await login({
          username: 'admin',
          password: '123456'
        })
        
        // 登录成功后获取用户信息
        const userInfo = await getUserInfo()
        console.log(userInfo)
        
      } catch (error) {
        console.error('请求失败:', error)
      }
    }
  }
}
</script>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值