用Axios Element实现全局的请求loading的方法


Posted in Javascript onMarch 15, 2018

背景

业务需求是这样子的,每当发请求到后端时就触发一个全屏的 loading,多个请求合并为一次 loading。

现在项目中用的是 vue 、axios、element等,所以文章主要是讲如果使用 axios 和 element 实现这个功能。

效果如下:

用Axios Element实现全局的请求loading的方法

分析

首先,请求开始的时候开始 loading, 然后在请求返回后结束 loading。重点就是要拦截请求和响应。

然后,要解决多个请求合并为一次 loading。

最后,调用element 的 loading 组件即可。

拦截请求和响应

axios 的基本使用方法不赘述。笔者在项目中使用 axios 是以创建实例的方式。

// 创建axios实例
const $ = axios.create({
 baseURL: `${URL_PREFIX}`,
 timeout: 15000
})

然后再封装 post 请求(以 post 为例)

export default {
 post: (url, data, config = { showLoading: true }) => $.post(url, data, config)
}

axios 提供了请求拦截和响应拦截的接口,每次请求都会调用showFullScreenLoading方法,每次响应都会调用tryHideFullScreenLoading()方法

// 请求拦截器
$.interceptors.request.use((config) => {
 showFullScreenLoading()
 return config
}, (error) => {
 return Promise.reject(error)
})

// 响应拦截器
$.interceptors.response.use((response) => {
 tryHideFullScreenLoading()
 return response
}, (error) => {
 return Promise.reject(error)
})

那么showFullScreenLoading tryHideFullScreenLoading()要干的事儿就是将同一时刻的请求合并。声明一个变量needLoadingRequestCount,每次调用showFullScreenLoading方法 needLoadingRequestCount + 1。调用tryHideFullScreenLoading()方法,needLoadingRequestCount - 1。needLoadingRequestCount为 0 时,结束 loading。

let needLoadingRequestCount = 0

export function showFullScreenLoading() {
 if (needLoadingRequestCount === 0) {
  startLoading()
 }
 needLoadingRequestCount++
}

export function tryHideFullScreenLoading() {
 if (needLoadingRequestCount <= 0) return
 needLoadingRequestCount--
 if (needLoadingRequestCount === 0) {
  endLoading()
 }
}

startLoading()和endLoading()就是调用 element 的 loading 方法。

import { Loading } from 'element-ui'
let loading
function startLoading() {
 loading = Loading.service({
  lock: true,
  text: '加载中……',
  background: 'rgba(0, 0, 0, 0.7)'
 })
}

function endLoading() {
 loading.close()
}

到这里,基本功能已经实现了。每发一个 post 请求,都会显示全屏 loading。同一时刻的多个请求合并为一次 loading,在所有响应都返回后,结束 loading。

功能增强

实际上,现在的功能还差一点。如果某个请求不需要 loading 呢,那么发请求的时候加个  showLoading: false的参数就好了。在请求拦截和响应拦截时判断下该请求是否需要loading,需要 loading 再去调用showFullScreenLoading()方法即可。

在封装 post 请求时,已经在第三个参数加了 config 对象。config 里包含了 showloading。然后在拦截器中分别处理。

// 请求拦截器
$.interceptors.request.use((config) => {
 if (config.showLoading) {
  showFullScreenLoading()
 }
 return config
})

// 响应拦截器
$.interceptors.response.use((response) => {
 if (response.config.showLoading) {
  tryHideFullScreenLoading()
 }
 return response
})

我们在调用 axios 时把 config 放在第三个参数中,axios 会直接把 showloading 放在请求拦截器的回调参数里,可以直接使用。在响应拦截器中的回调参数 response 中则是有一个 config 的 key。这个 config 则是和请求拦截器的回调参数 config 一样。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS学习之一个简易的日历控件
Mar 24 Javascript
JavaScript设计模式之适配器模式介绍
Dec 28 Javascript
Es6 写的文件import 起来解决方案详解
Dec 13 Javascript
js正则表达式验证密码强度【推荐】
Mar 03 Javascript
vue父子组件的数据传递示例
Mar 07 Javascript
关于js中的鼠标事件总结
Jul 11 Javascript
基于vue的短信验证码倒计时demo
Sep 13 Javascript
微信小程序实现图片上传、删除和预览功能的方法
Dec 18 Javascript
element-ui 的el-button组件中添加自定义颜色和图标的实现方法
Oct 26 Javascript
layui自定义插件citySelect实现省市区三级联动选择
Jul 26 Javascript
简单了解JavaScript作用域
Jul 31 Javascript
JS实现公告上线滚动效果
Jan 10 Javascript
基于IView中on-change属性的使用详解
Mar 15 #Javascript
解决iView中时间控件选择的时间总是少一天的问题
Mar 15 #Javascript
iview日期控件,双向绑定日期格式的方法
Mar 15 #Javascript
vue iview组件表格 render函数的使用方法详解
Mar 15 #Javascript
微信小程序实现换肤功能
Mar 14 #Javascript
Angular4集成ng2-file-upload的上传组件
Mar 14 #Javascript
iview table高度动态设置方法
Mar 14 #Javascript
You might like
PHP的几个常用数字判断函数代码
2012/04/24 PHP
php上传excel表格并获取数据
2017/04/27 PHP
Laravel项目中timeAgo字段语言转换的改善方法示例
2019/09/16 PHP
php中yar框架实例用法讲解
2020/12/27 PHP
IE和Firefox下javascript的兼容写法小结
2008/12/10 Javascript
JavaScript库 开发规则
2009/01/31 Javascript
编写兼容IE和FireFox的脚本
2009/05/18 Javascript
JavaScript Event学习第三章 早期的事件处理程序
2010/02/07 Javascript
javascript/jquery获取地址栏url参数的方法
2014/03/05 Javascript
Javascript实现简单二级下拉菜单实例
2014/06/15 Javascript
使用jQuery不判断浏览器高度解决iframe自适应高度问题
2014/12/16 Javascript
学习JavaScript设计模式之单例模式
2016/01/19 Javascript
Webwork 实现文件上传下载代码详解
2016/02/02 Javascript
关于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
2016/06/30 Javascript
使用Bootstrap typeahead插件实现搜索框自动补全的方法
2016/07/07 Javascript
Swiper实现轮播图效果
2017/07/03 Javascript
JS去掉字符串中所有的逗号
2017/10/18 Javascript
jq.ajax+php+mysql实现关键字模糊查询(示例讲解)
2018/01/02 Javascript
Java设计中的Builder模式的介绍
2018/03/22 Javascript
node实现的爬虫功能示例
2018/05/04 Javascript
微信小程序上线发布流程图文详解
2019/05/06 Javascript
JavaScript对象原型链原理解析
2020/01/22 Javascript
python语音识别实践之百度语音API
2018/08/30 Python
Scrapy使用的基本流程与实例讲解
2018/10/21 Python
对pandas的算术运算和数据对齐实例详解
2018/12/22 Python
python整小时 整天时间戳获取算法示例
2019/02/20 Python
python实现动态数组的示例代码
2019/07/15 Python
如何使用Python多线程测试并发漏洞
2019/12/18 Python
python实现梯度下降法
2020/03/24 Python
Ajax实现页面无刷新留言效果
2021/03/24 Javascript
文化活动实施方案
2014/03/28 职场文书
风雨哈佛路观后感
2015/06/03 职场文书
男方家长婚礼答谢词
2015/09/29 职场文书
2019年员工晋升管理制度范本!
2019/07/08 职场文书
创业分两种人:那么哪些适合创业?,哪些适合不适合创业呢?
2019/08/23 职场文书
Python使用sql语句对mysql数据库多条件模糊查询的思路详解
2021/04/12 Python