项目实用功能-全局loading动画

简介: 项目实用功能-全局loading动画

1.为设么要使用全局loading


调用的每一个接口都要绑定一个loading真的很烦。


2.实现这个需要考虑哪些要素


首先全局的loading需要一个调用任何接口都要执行的地方打开,那就肯定是axios的前置拦截函数了。

loading有加载整个页面的,也有加载部分页面的(下拉框内容展示区等),所以不是所有接口都能使用全局loading,这就需要使用一个白名单,只对白名单内存在的接口进行处理

关闭loading,那就肯定是axios的后置拦截函数了。

当同时请求多个接口,如何判断所有接口请求完成后关闭loading。用一个数组存储请求的接口路径,axios后置拦截函数中删除数组中返回状态的接口,数组长度=0,关闭loading即可。


3.实现


let apiList = [];  // 存储请求的接口
api.interceptors.request.use(
    request => {
        let {interfaceLoading,whiteList} = store.state.global
        // 启动全局loding
        if(whiteList.indexOf(request.url) > -1 && !interfaceLoading){
            store.commit('global/setInterfaceLoading',true)
            // 记录请求接口,用于判断何时取消loading
            apiList.push(request.url)
        }
        return request
    }
)
api.interceptors.response.use(
    response => {
        // 清除请求地址,清空则取消loading
        let index = apiList.findIndex((item)=>item===response.config.url)
        if(index!==-1){
            apiList.splice(index,1)
        }
        if(apiList.length===0){
            store.commit('global/setInterfaceLoading',false)
        }
        // 以下为处理返回数据结果
        if (response.data) {
            if (response.data.status === 200) {
                return Promise.resolve(response.data)
            }
            else if (response.data.errorType) {
                // alert.typeOne('error',response.data.msg)
                return Promise.resolve(response.data)
            } else {
                // 请求成功并且没有报错
                return Promise.resolve(response.data)
            }
        } else {
            toLogin()
        }
    }
相关文章
|
前端开发 JavaScript API
020 Umi@4 中如何实现动态菜单
020 Umi@4 中如何实现动态菜单
1098 0
020 Umi@4 中如何实现动态菜单
|
6月前
|
前端开发
如何在前端项目中单独引入 ElementUI 图标以及使用
这篇文章介绍了如何在前端项目中单独引入Element UI的图标文件以及如何使用这些图标。
526 0
如何在前端项目中单独引入 ElementUI 图标以及使用
|
6月前
|
前端开发 JavaScript 机器人
中后台前端开发问题之动态标注组件渲染到界面上如何解决
中后台前端开发问题之动态标注组件渲染到界面上如何解决
42 0
|
7月前
|
JSON 小程序 数据库
【微信小程序-原生开发】实用教程14 - 列表的分页加载,触底加载更多(含无更多数据的提醒和显示,自定义组件)
【微信小程序-原生开发】实用教程14 - 列表的分页加载,触底加载更多(含无更多数据的提醒和显示,自定义组件)
170 0
|
8月前
|
前端开发 程序员 UED
全面解析layui:掌握基础知识与实用技能(1. 核心组件与模块 2. 布局与容器 3. 弹出层与提示框;1. 数据表格与数据表单 2. 表单验证与提交 3. 图片轮播与导航菜单)
全面解析layui:掌握基础知识与实用技能(1. 核心组件与模块 2. 布局与容器 3. 弹出层与提示框;1. 数据表格与数据表单 2. 表单验证与提交 3. 图片轮播与导航菜单)
102 0
|
9月前
|
PHP
【最全最详细】使用publiccms实现动态可维护的首页轮播
【最全最详细】使用publiccms实现动态可维护的首页轮播
|
9月前
|
小程序
【微信小程序】-- WXSS 模板样式- 全局样式和局部样式(十四)
【微信小程序】-- WXSS 模板样式- 全局样式和局部样式(十四)
|
9月前
|
小程序 自动驾驶 IDE
静态懒加载+占位组件,让页面打开“快人一步”
静态懒加载+占位组件,让页面打开“快人一步”
100 0
|
前端开发 JavaScript
前端动画(动态)图标库收集
前端动画(动态)图标库收集
176 0
|
前端开发
给 Antd Table 组件编写缩进指引线、子节点懒加载等功能,如何二次封装开源组件?
在业务需求中,有时候我们需要基于 antd 之类的组件库定制很多功能,本文就以我自己遇到的业务需求为例,一步步实现和优化一个树状表格组件,这个组件会支持: