vue 封装 Axios 接口与异常处理

1.新建文件夹api

vue 封装 Axios 接口与异常处理_第1张图片
如图

2. http.js

进行axios封装, 请求拦截、响应拦截、错误统一处理
代码如下:

import axios from 'axios';
/**请求失败后的错误统一处理 */
const errorHandle = (status, other) => {
    // 状态码判断
    switch (status) {
        // 401: 未登录状态,跳转登录页
        case 401:
            toLogin();
            break;
        // 403 token过期
        // 清除token并跳转登录页
        case 403:
            tip('登录过期,请重新登录');
            localStorage.removeItem('token');
            store.commit('loginSuccess', null);
            setTimeout(() => {
                toLogin();
            }, 1000);
            break;
        // 404请求不存在
        case 404:
            alert('请求的资源不存在');
            break;
        default:
            console.log(other);
        }
}

// 创建axios实例
const instance = axios.create({ timeout: 1000 * 12});
// 设置post请求头
instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
/**
 * 请求拦截器
 * 每次请求前,如果存在token则在请求头中携带token
 */
instance.interceptors.request.use(
    config => {
      let token = window.localStorage.getItem('token');
      if (token) { //判断token是否存在
        config.headers.Authorization = token;  //将token设置成请求头
      }
      return config;
    },
    err => {
      return Promise.reject(err);
    }
  );
/**
 * 响应拦截器
 * 判断登录是否过期,断网处理
 */
instance.interceptors.response.use(
 // 请求成功
    res => res.status === 200 ? Promise.resolve(res) : Promise.reject(res),
    // 请求失败
    error => {
        const { response } = error;
        if (response) {
            // 请求已发出,但是不在2xx的范围
            errorHandle(response.status, response.data.message);
            return Promise.reject(response);
        } else {
            // 处理断网的情况
            // eg:请求超时或断网时,更新state的network状态
            // network状态在app.vue中控制着一个全局的断网提示组件的显示隐藏
            // 关于断网组件中的刷新重新获取数据,会在断网组件中说明
            // store.commit('changeNetwork', false);
        }
    });

export default instance;

2. base.js

接口域名的管理,代码如下

const base = {
    baseURL:'http://localhost:3000'
};
export default  base;

3. todos.js

todos模块接口列表,代码如下:

import http from './http'; //封装的拦截器及错误处理的axios
import base from './base'; //配置的接口域名

const todosApi = {
   getTodoList (){
        return http.get(`${base.baseURL}/getTodoList`)
    },
   addTodoList (data){
        return http.post(`${base.baseURL}/addTodoList`,{
            ...data,
        })
    }
};
export default  todosApi;

4.index.js

api接口的统一出口,利于多人协作开发
代码如下:

// todos模块接口
import todosApi from './todos';
// 其他模块的接口……

// 导出接口
export default {
    todosApi,
    // ……
}

5.main.js中去挂载axios

import api from './api'  //相当于引入index.js中导出的api接口
Vue.prototype.$api = api;  // 将api挂载到vue的原型上

6.TodoList.vue 组件中去调用接口

created(){
     this.getTodos()
},
 methods:{
     // 得到数据
     getTodos(){
       this.$api.todosApi.getTodoList()   //可直接调用todosApi中的方法
             .then(res=> {
                   this.todos = res.data.todos;
             })  
       },
    // 添加数据
     addTodos(){
       this.$api.todosApi.addTodoList({
              name: 'little fairy',
              age: 12
        })  
        .then(res=> {
               this.todos = res.data.todos;
         })  
    },
}

总结:
这样可以统一的操作api接口,进行统一的封装,及异常处理,便于后期的维护更新,以及提高代码的简洁性

你可能感兴趣的:(vue 封装 Axios 接口与异常处理)