用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中用星号表示预录入内容的实现代码
Jan 08 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
Dec 11 Javascript
jquery获得option的值和对option进行操作
Dec 13 Javascript
js鼠标点击图片切换效果代码分享
Aug 26 Javascript
详解Node.Js如何处理post数据
Sep 19 Javascript
使用ReactJS实现tab页切换、菜单栏切换、手风琴切换和进度条效果
Oct 17 Javascript
可输入文字查找ajax下拉框控件 ComBox的实现方法
Oct 25 Javascript
Vue-router 类似Vuex实现组件化开发的示例
Sep 15 Javascript
vue实例中data使用return包裹的方法
Aug 27 Javascript
Vue项目从webpack3.x升级webpack4不完全指南
Apr 28 Javascript
Vue的状态管理vuex使用方法详解
Feb 05 Javascript
eslint+prettier统一代码风格的实现方法
Jul 22 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中static静态变量的使用方法详解
2010/06/04 PHP
php中将数组存到文件里的实现代码
2012/01/19 PHP
php递归使用示例(php递归函数)
2014/02/14 PHP
完善CodeIgniter在IDE中代码提示功能的方法
2014/07/19 PHP
Laravel中注册Facades的步骤详解
2016/03/16 PHP
CI框架(CodeIgniter)操作redis的方法详解
2018/01/25 PHP
js 获取Listbox选择的值的代码
2010/04/15 Javascript
jQuery学习笔记之控制页面实现代码
2012/02/27 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
2016/10/27 Javascript
Vue监听数据对象变化源码
2017/03/09 Javascript
使用express搭建一个简单的查询服务器的方法
2018/02/09 Javascript
iview table render集成switch开关的实例
2018/03/14 Javascript
详解NodeJs开发微信公众号
2018/05/25 NodeJs
这应该是最详细的响应式系统讲解了
2019/07/22 Javascript
vue动态禁用控件绑定disable的例子
2019/10/28 Javascript
vue实现商品列表的添加删除实例讲解
2020/05/14 Javascript
JavaScript闭包原理与用法学习笔记
2020/05/29 Javascript
详解基于element的区间选择组件校验(交易金额)
2021/01/07 Javascript
[55:35]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第二场 1月22日
2021/03/11 DOTA
深入浅出学习python装饰器
2017/09/29 Python
Python语言描述机器学习之Logistic回归算法
2017/12/21 Python
Python爬虫通过替换http request header来欺骗浏览器实现登录功能
2018/01/07 Python
对python 各种删除文件失败的处理方式分享
2018/04/24 Python
Centos部署django服务nginx+uwsgi的方法
2019/01/02 Python
python xpath获取页面注释的方法
2019/01/14 Python
python实现在函数图像上添加文字和标注的方法
2019/07/08 Python
python GUI库图形界面开发之PyQt5打开保存对话框QFileDialog详细使用方法与实例
2020/02/27 Python
python导入库的具体方法
2020/06/18 Python
python 用opencv实现图像修复和图像金字塔
2020/11/27 Python
python+playwright微软自动化工具的使用
2021/02/02 Python
关于HTML5你必须知道的28个新特性,新技巧以及新技术
2012/05/28 HTML / CSS
考试诚信承诺书
2014/05/23 职场文书
科技活动周标语
2014/10/08 职场文书
MySQL Shell import_table数据导入的实现
2021/08/07 MySQL
java版 联机五子棋游戏
2022/05/04 Java/Android
mysql性能优化以及配置连接参数设置
2022/05/06 MySQL