用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 相关文章推荐
javascript下操作css的float属性的特殊写法
Aug 22 Javascript
jQuery 选择表格(table)里的行和列及改变简单样式
Dec 15 Javascript
js Math 对象的方法
Sep 01 Javascript
JS获取select-option-text_value的方法
Dec 26 Javascript
js语法学习之判断一个对象是否为数组
May 13 Javascript
javascript事件委托的用法及其好处简析
Apr 04 Javascript
BootStrap的table表头固定tbody滚动的实例代码
Aug 24 Javascript
AngularJS的依赖注入实例分析(使用module和injector)
Jan 19 Javascript
node.js中fs.stat与fs.fstat的区别详解
Jun 01 Javascript
underscore之Chaining_动力节点Java学院整理
Jul 10 Javascript
详解小程序输入框闪烁及重影BUG解决方案
Aug 31 Javascript
vue实现的仿淘宝购物车功能详解
Jan 27 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
在WordPress中使用wp-cron插件来设置定时任务
2015/12/10 PHP
利用PHP访问MySql数据库的逻辑操作以及增删改查的实例讲解
2017/08/30 PHP
PHP7匿名类的用法示例
2019/04/05 PHP
使用jQuery.Validate进行客户端验证(初级篇) 不使用微软验证控件的理由
2010/06/28 Javascript
jQuery+css+html实现页面遮罩弹出框
2013/03/21 Javascript
JavaScript中几个重要的属性(this、constructor、prototype)介绍
2013/05/19 Javascript
页面加载完毕后滚动条自动滚动一定位置
2014/02/20 Javascript
给js文件传参数(详解)
2014/07/13 Javascript
jQuery的position()方法详解
2015/07/19 Javascript
详解JavaScript中数组的相关知识
2015/07/29 Javascript
JavaScript 性能优化小结
2015/10/12 Javascript
基于jquery实现智能表单验证操作
2016/05/09 Javascript
Bootstrap3制作自己的导航栏
2016/05/12 Javascript
vue.js入门(3)——详解组件通信
2016/12/02 Javascript
详解vue事件对象、冒泡、阻止默认行为
2017/03/20 Javascript
基于AngularJS实现表单验证功能
2017/07/28 Javascript
细说Vue组件的服务器端渲染的过程
2019/05/30 Javascript
layui插件表单验证提交触发提交的例子
2019/09/09 Javascript
Python使用函数默认值实现函数静态变量的方法
2014/08/18 Python
Python3.x对JSON的一些操作示例
2017/09/01 Python
浅谈Series和DataFrame中的sort_index方法
2018/06/07 Python
OpenCV 轮廓检测的实现方法
2019/07/03 Python
Jupyter打开图形界面并画出正弦函数图像实例
2020/04/24 Python
Python 实现 T00ls 自动签到脚本代码(邮件+钉钉通知)
2020/07/06 Python
localstorage和sessionstorage使用记录(推荐)
2017/05/23 HTML / CSS
eBay意大利购物网站:eBay.it
2019/09/04 全球购物
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
一些关于MySql加速和优化的面试题
2014/01/30 面试题
两则小学生的自我评价分享
2013/11/14 职场文书
幸福家庭事迹材料
2014/02/03 职场文书
环境工程专业自荐信
2014/03/03 职场文书
工伤事故赔偿协议书范文
2014/09/24 职场文书
鸟的天堂导游词
2015/01/31 职场文书
2016党性教育学习心得体会
2016/01/21 职场文书
nginx实现发布静态资源的方法
2021/03/31 Servers
Win11 BitLocker 驱动器加密
2022/04/19 数码科技