用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中如何把一段html代码动态写入到DIV中(实例说明)
Jul 09 Javascript
jQuery多级手风琴菜单实例讲解
Oct 22 Javascript
javascript简单比较日期大小的方法
Jan 05 Javascript
无缝滚动的简单实现代码(推荐)
Jun 07 Javascript
node.js 利用流实现读写同步,边读边写的方法
Sep 11 Javascript
JS+HTML实现的圆形可点击区域示例【3种方法】
Aug 01 Javascript
layui 表格的属性的显示转换方法
Aug 14 Javascript
vue中promise的使用及异步请求数据的方法
Nov 08 Javascript
微信小程序实现文字跑马灯
May 26 Javascript
使用VueCli3+TypeScript+Vuex一步步构建todoList的方法
Jul 25 Javascript
js+cavans实现图片滑块验证
Sep 29 Javascript
简单谈谈offsetleft、offsetTop和offsetParent
Dec 04 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 base64编码后解码乱码的解决办法
2014/06/19 PHP
使用PHP Socket 编程模拟Http post和get请求
2014/11/25 PHP
DOM 基本方法
2009/07/18 Javascript
js监听表单value的修改同步问题,跨浏览器支持
2009/12/31 Javascript
加速IE的Javascript document输出的方法
2010/12/02 Javascript
jQuery 三击事件实现代码
2013/09/11 Javascript
js和php如何获取当前url的内容
2013/09/22 Javascript
基于jquery插件制作左右按钮与标题文字图片切换效果
2013/11/07 Javascript
JS兼容浏览器的导出Excel(CSV)文件的方法
2014/05/03 Javascript
JavaScript实现非常简单实用的下拉菜单效果
2015/08/27 Javascript
基于javascript实现句子翻牌网页版小游戏
2016/03/23 Javascript
jQuery Mobile中的button按钮组件基础使用教程
2016/05/23 Javascript
AngularJs Understanding the Model Component
2016/09/02 Javascript
10道典型的JavaScript面试题
2017/03/22 Javascript
Angular事件之不同组件间传递数据的方法
2018/11/15 Javascript
python进阶教程之函数对象(函数也是对象)
2014/08/30 Python
Python运用于数据分析的简单教程
2015/03/27 Python
python开启多个子进程并行运行的方法
2015/04/18 Python
Python符号计算之实现函数极限的方法
2019/07/15 Python
python为什么会环境变量设置不成功
2020/06/23 Python
浅谈关于html5中图片抛物线运动的一些心得
2018/01/09 HTML / CSS
使用Html5中的cavas画一面国旗
2019/09/25 HTML / CSS
关于Assembly命名空间的三个面试题
2015/07/23 面试题
优秀民警事迹材料
2014/01/29 职场文书
丑小鸭教学反思
2014/02/03 职场文书
学习十八大坚定理想信念心得体会
2014/03/11 职场文书
课程改革实施方案
2014/03/16 职场文书
网络编辑岗位职责
2014/03/18 职场文书
擅自离岗检讨书
2014/09/12 职场文书
2015年小学总务工作总结
2015/07/21 职场文书
干部考核工作总结
2015/08/12 职场文书
2016会计专业自荐信范文
2016/01/28 职场文书
2019年描写人生经典诗句大全
2019/07/08 职场文书
Java集成swagger文档组件
2021/06/28 Java/Android
SQL注入详解及防范方法
2021/12/06 MySQL
Redis过期数据是否会被立马删除
2022/07/23 Redis