用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 UI皮肤定制
Jul 27 Javascript
Array.prototype.concat不是通用方法反驳[译]
Sep 20 Javascript
JavaScript中的运算符种类及其规则介绍
Sep 26 Javascript
js每隔5分钟执行一次ajax请求的实现方法
Nov 27 Javascript
Javascript 遍历页面text控件详解
Jan 06 Javascript
深入探讨JavaScript String对象
Mar 09 Javascript
jQuery+css实现的时钟效果(兼容各浏览器)
Jan 27 Javascript
jQuery实现字符串全部替换的方法【推荐】
Mar 09 Javascript
javascript编程开发中取色器及封装$函数用法示例
Aug 09 Javascript
vue-resource拦截器设置头信息的实例
Oct 27 Javascript
jquery实现Ajax请求的几种常见方式总结
May 28 jQuery
让 babel webpack vue 配置文件支持智能提示的方法
Jun 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
web方式ftp
2006/10/09 PHP
PHP中MVC模式的模板引擎开发经验分享
2011/03/23 PHP
PHP实现GIF图片验证码
2015/11/04 PHP
PHP文字转图片功能原理与实现方法分析
2017/08/31 PHP
php异常处理捕获错误整理
2019/09/23 PHP
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
javascript倒计时效果实现
2015/11/12 Javascript
js实现开启密码大写提示
2016/12/21 Javascript
RequireJs的使用详解
2017/02/19 Javascript
Angular.js之作用域scope'@','=','&amp;'实例详解
2017/02/28 Javascript
JavaScript实现百度搜索框效果
2020/03/26 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
原生JS实现列表子元素顺序反转的方法分析
2018/07/02 Javascript
Vue 通过自定义指令回顾v-内置指令(小结)
2018/09/03 Javascript
了解在JavaScript中将值转换为字符串的5种方法
2019/06/06 Javascript
vue中js判断长时间不操作界面自动退出登录(推荐)
2020/01/22 Javascript
vue elementui tree 任意级别拖拽功能代码
2020/08/31 Javascript
python3.3教程之模拟百度登陆代码分享
2014/01/16 Python
利用Python将时间或时间间隔转为ISO 8601格式方法示例
2017/09/05 Python
python实现数据写入excel表格
2018/03/25 Python
Python走楼梯问题解决方法示例
2018/07/25 Python
Python数据类型之Dict字典实例详解
2019/05/07 Python
Python整数对象实现原理详解
2019/07/01 Python
详解python中的数据类型和控制流
2019/08/08 Python
Django项目使用ckeditor详解(不使用admin)
2019/12/17 Python
python-sys.stdout作为默认函数参数的实现
2020/02/21 Python
Django 解决开发自定义抛出异常的问题
2020/05/21 Python
Harrods美国:英国最大的百货公司
2018/11/04 全球购物
《长城》教学反思
2014/02/14 职场文书
售前工程师职业生涯规划
2014/03/02 职场文书
护理助产毕业生的求职信
2014/03/02 职场文书
学校先进集体事迹材料
2014/05/31 职场文书
会计毕业生自荐书
2014/06/12 职场文书
行政前台岗位职责
2015/04/16 职场文书
《索溪峪的野》教学反思
2016/02/19 职场文书
年中了,该如何写好个人述职报告?
2019/07/02 职场文书