axios请求封装

  1. 首先在vue项目下安装axios以及支持异步提示的iView组件库

    npm install axios

    npm install iview

  2. 在src文件夹下新建axios文件夹,在其中新建api.js用于存放接口,request.js用于封装axios对象

avatar

  1. 编写request.js

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    
    import axios from "axios";
    import Vue from 'vue'
     
    const service = axios.create({
      // baseURL: process.env.BASE_URl,
      baseURL: "http://localhost:8081/api",
      timeout: 5000
    }); //axios对象,设置公共地址和超时
    
    //请求拦截
    service.interceptors.request.use(config => {
      Vue.prototype.$Loading.start();//异步加载的进度条
      config.headers['token'] = window.localStorage.getItem('token');//公共请求头
      return config;
    },error => {
      Vue.prototype.$Loading.error();
      console.log(error)
    });
     
    // 响应拦截
    service.interceptors.response.use(response => {
      Vue.prototype.$Loading.finish();
      if (response.status.code === 200){
        return response.data.data;
      } else{
        console.log("请求出错")
      }
    },error => {
      Vue.prototype.$Loading.error();
      console.log(error)
    });
     
    export default service;
    

    最后将service暴露出去,在api.js中引入service,即可使用包装好的axios,包括baseUrl和token请求头,以及对响应的判断,这样的话在api.js中只需要关注业务就行。

  2. 编写api.js

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    
    import service from './request'
    
    export const login = data => {
      return service({
        url: '/user/login',
        method: 'post',
        data: JSON.stringify(data)
      })
    }
    
    //..others
    
  1. 在页面中使用
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    
    import {login} from "../axios/api" //按需导入
    
    export default {
        // ...
        methods: {
          // ...
          
          async login(){
            let userName = this.userName;
            let password = this.password;
            if (!userName||!password){
              this.$Message.error("信息需填写完整")
            } else
            await login({userName,password});
          }
        },
        // ...
    }
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值