用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 相关文章推荐
jquery checkbox,radio是否选中的判断代码
Mar 20 Javascript
CodeMirror2 IE7/IE8 下面未知运行时错误的解决方法
Mar 29 Javascript
使用JQuery库提供的扩展功能实现自定义方法
Sep 09 Javascript
drag-and-drop实现图片浏览器预览
Aug 06 Javascript
详解Bootstrap的iCheck插件checkbox和radio
Aug 24 Javascript
jQuery动态生成表格及右键菜单功能示例
Jan 13 Javascript
Angular2-primeNG文件上传模块FileUpload使用详解
Jan 14 Javascript
基于jQuery实现数字滚动效果
Jan 16 Javascript
详解VueJs前后端分离跨域问题
May 24 Javascript
用JavaScript做简易的购物车的代码示例
Oct 20 Javascript
原生js实现二级联动菜单
Nov 27 Javascript
vue分页插件的使用方法
Dec 25 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
深入理解ob_flush和flush的区别(ob_flush()与flush()使用方法)
2013/02/06 PHP
php获取本地图片文件并生成xml文件输出具体思路
2013/04/27 PHP
php类中的各种拦截器用法分析
2014/11/03 PHP
php更新mysql后获取改变行数的方法
2014/12/25 PHP
thinkPHP连接sqlite3数据库的实现方法(附Thinkphp代码生成器下载)
2016/05/27 PHP
js文字滚动停顿效果代码
2008/06/28 Javascript
JS提交并解析后台返回的XML的代码
2008/11/03 Javascript
javascript管中窥豹 形参与实参浅析
2011/12/17 Javascript
理解javascript异步编程
2016/01/27 Javascript
window.onerror()的用法与实例分析
2016/01/27 Javascript
jQuery+ajax+asp.net获取Json值的方法
2016/06/08 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
element vue Array数组和Map对象的添加与删除操作
2018/11/14 Javascript
vue表单中遍历表单操作按钮的显示隐藏示例
2019/10/30 Javascript
js实现无缝轮播图特效
2020/05/09 Javascript
[44:47]Ti4 循环赛第三日 iG vs NaVi
2014/07/12 DOTA
python对json的相关操作实例详解
2017/01/04 Python
python正则分析nginx的访问日志
2017/01/17 Python
Python matplotlib学习笔记之坐标轴范围
2019/06/28 Python
在python中画正态分布图像的实例
2019/07/08 Python
flask 框架操作MySQL数据库简单示例
2020/02/02 Python
使用python执行shell脚本 并动态传参 及subprocess的使用详解
2020/03/06 Python
numpy 矩阵形状调整:拉伸、变成一位数组的实例
2020/06/18 Python
python报错: 'list' object has no attribute 'shape'的解决
2020/07/15 Python
PyCharm2020.1.1与Python3.7.7的安装教程图文详解
2020/08/07 Python
总结html5自定义属性有哪些
2020/04/01 HTML / CSS
产品工艺师的岗位职责
2013/11/15 职场文书
办理暂住证介绍信
2014/01/11 职场文书
买房协议书
2014/04/11 职场文书
师德演讲稿范文
2014/05/06 职场文书
2015年材料员工作总结
2015/04/30 职场文书
2015年教务工作总结
2015/05/23 职场文书
论文评审意见
2015/06/05 职场文书
小学生安全教育心得体会
2016/01/15 职场文书
MySQL 时间类型的选择
2021/06/05 MySQL
Python测试框架pytest核心库pluggy详解
2022/08/05 Golang