vue 封装 Axios 接口与异常处理

学习引用自:小本YuDL

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.response.use(
 // 请求成功
    res => res.status === 200 ? Promise.resolve(res) : Promise.reject(res),
    // 请求失败
    error => {
        const { response } = error;
        if (response) {
            // 请求已发出,但是不在2xx的范围
            return Promise.reject(response);
        } else {
            // 处理断网的情况
            // eg:请求超时或断网时,更新state的network状态
            // network状态在app.vue中控制着一个全局的断网提示组件的显示隐藏
            // 关于断网组件中的刷新重新获取数据,会在断网组件中说明
            // store.commit('changeNetwork', false);
        }
    });

export default instance;
3. base.js

接口域名的管理

const base = {
    baseURL:'http://localhost:8888'
};
export default  base;
4. todos.js

todos模块接口列表

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

const todosApi = {
   getTodoList (res){
        return http.post(`${base.baseURL}/chat/selChatList`, {
            id : res
          })
    }
};
export default  todosApi;
5.index.js

api接口的统一出口,利于多人协作开发

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

// 导出接口
export default {
    todosApi,
    // ……
}
6.main.js中去挂载axios
import api from './api'  //相当于引入index.js中导出的api接口
Vue.prototype.$api = api;  // 将api挂载到vue的原型上
7. 组件中去调用接口
created(){
   this.getTodos()
},
methods: {
  //得到数据
    getTodos() {
      this.$api.todosApi
        .getTodoList(1) //可直接调用todosApi中的方法
        .then(res => {
          console.log(res);
        });
    }
}

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