美文网首页vue技术文档前端全栈架构设计
vue 封装 Axios 接口与异常处理

vue 封装 Axios 接口与异常处理

作者: 小本YuDL | 来源:发表于2020-03-04 18:04 被阅读0次

    1.新建文件夹api

    如图

    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;
    

    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`)
        }
    };
    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;
                 })  
           }
    }
    

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

    相关文章

      网友评论

        本文标题:vue 封装 Axios 接口与异常处理

        本文链接:https://www.haomeiwen.com/subject/prmblhtx.html