vue工程全局设置ajax的等待动效的方法


Posted in Javascript onFebruary 22, 2019

最近在做vue的项目,使用了element-ui作为ui组件库,采用vuex进行状态管理,与后台的请求交互采用axios库实现,原本做的页面,ajax请求个数也只有三个,将等待动画的显示和隐藏通过mutation去控制,但是项目越来越大,请求也越来越多,能否将这个等待动画与ajax的请求相关联呢?

实现等待动效

在element-ui中,提供了两个方法进行调用loading组件,一个是在需要遮罩的div容器中添加v-loading指令,另一种就是以服务形式调用:Loading.service(options),在本项目中,在加载数据时,进行全局遮罩,所以设置let loadingInstance = Loading.service({fullscreen:true})。关闭服务形式的调用:loadingInstance.close();

axios的拦截器

个人对拦截器的作用的理解是,在请求发送前和响应处理前,对该ajax请求进行一定的设置或者处理,方便对工程内的ajax请求进行统一处理,减少重复代码。

//请求拦截器
 axios.interceptors.request.use((config) => {
  // 在发送请求之前做些什么
  return config;
 }, (error) => {
  // 对请求错误做些什么
  return Promise.reject(error);
 });
 // 添加响应拦截器
 axios.interceptors.response.use((response) => {
  // 对响应数据做点什么
  return response;
 }, (error) => {
  // 对响应错误做点什么
  return Promise.reject(error);
 });

有了拦截器,我们可以想到,在ajax请求发送前开启loading动画,在接收响应后关闭loading动画。但是要对每个ajax都开关一下loading动画吗?其实不必。只需要实现一个ajax的计数器,在个数大于0时,开启动画,在个数为0的时候,关闭动画。

计数器实现

let loadingInstance;
let loadCounter = {
  count:0,
  show:() => {
    if(count < 0){
     this.count ++;
     loadingInstance = Loading.service({fullscreen:true});
    }
  },
  hide:()=>{
    if(count > 0){
      this.count --;
      this.$nextTick(()=>{//以服务的方式调用的 Loading 需要异步关闭
        loadingInstance.close();
      });
    }
  }
}

使用方法

//请求拦截器
 axios.interceptors.request.use((config) => {
  loadCounter.show();
  return config;
 }, (error) => {
  return Promise.reject(error);
 });
 // 添加响应拦截器
 axios.interceptors.response.use((response) => {
  loadCounter.hide();
  return response;
 }, (error) => {
  return Promise.reject(error);
 });

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery属性过滤选择器使用示例
Jun 18 Javascript
让jQuery Mobile不显示讨厌loading界面的方法
Feb 19 Javascript
浅谈 javascript 事件处理
Jan 04 Javascript
JavaScript通过字典进行字符串翻译转换的方法
Mar 19 Javascript
js+html5操作sqlite数据库的方法
Feb 02 Javascript
Jquery组件easyUi实现选项卡切换示例
Aug 23 Javascript
对Angular.js Controller如何进行单元测试
Oct 25 Javascript
AngularJS中下拉框的高级用法示例
Oct 11 Javascript
Vue组件化开发思考
Feb 02 Javascript
详解swipe使用及竖屏页面滚动方法
Jun 28 Javascript
微信小程序使用swiper组件实现层叠轮播图
Nov 04 Javascript
JavaScript中filter的用法实例分析
Feb 27 Javascript
JavaScript数据结构与算法之检索算法示例【二分查找法、计算重复次数】
Feb 22 #Javascript
详解基于iview-ui的导航栏路径(面包屑)配置
Feb 22 #Javascript
JavaScript数据结构与算法之检索算法实例分析【顺序查找、最大最小值、自组织查询】
Feb 22 #Javascript
Fundebug支持监控微信小程序HTTP请求错误的方法
Feb 21 #Javascript
用Fundebug插件记录网络请求异常的方法
Feb 21 #Javascript
VUE搭建手机商城心得和遇到的坑
Feb 21 #Javascript
利用vue重构有赞商城的思路以及总结整理
Feb 21 #Javascript
You might like
层叠菜单的动态生成
2006/10/09 PHP
PHP编程之高级技巧——利用Mysql函数
2006/10/09 PHP
PHP开发中常用的字符串操作函数
2011/02/08 PHP
浅析PHP 按位与或 (^ 、&amp;)
2013/06/21 PHP
ThinkPHP访问不存在的模块跳转到404页面的方法
2014/06/19 PHP
php发送与接收流文件的方法
2015/02/11 PHP
PHPStorm+XDebug进行调试图文教程
2016/06/13 PHP
PHP与Web页面的交互示例详解一
2020/08/04 PHP
指定js可访问其它域名的cookie的方法
2007/09/18 Javascript
JavaScript.The.Good.Parts阅读笔记(一)假值与===运算符
2010/11/16 Javascript
JavaScript基础语法、dom操作树及document对象
2014/12/02 Javascript
使用jQuery和Bootstrap实现多层、自适应模态窗口
2014/12/22 Javascript
浅析$.getJSON异步请求和同步请求
2016/06/06 Javascript
JavaScript中全选、全不选、反选、无刷新删除、批量删除、即点即改入库(在yii框架中操作)的代码分享
2016/11/01 Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
2016/12/14 Javascript
垃圾回收器的相关知识点总结
2018/05/13 Javascript
使用json-server简单完成CRUD模拟后台数据的方法
2018/07/12 Javascript
vue.js watch经常失效的场景与解决方案
2021/01/07 Vue.js
用Python脚本来删除指定容量以上的文件的教程
2015/05/04 Python
python 字典(dict)按键和值排序
2016/06/28 Python
Python 中的with关键字使用详解
2016/09/11 Python
Python中scatter函数参数及用法详解
2017/11/08 Python
PHP实现发送和接收JSON请求
2018/06/07 Python
python实现一个简单的ping工具方法
2019/01/31 Python
python 使用while写猜年龄小游戏过程解析
2019/10/07 Python
Python搭建代理IP池实现检测IP的方法
2019/10/27 Python
python中time包实例详解
2021/02/02 Python
详解移动端HTML5音频与视频问题及解决方案
2018/08/22 HTML / CSS
一文彻底解决HTML5页面中长按保存图片功能
2019/06/10 HTML / CSS
使用数据结构给女朋友写个Html5走迷宫游戏
2019/11/26 HTML / CSS
丝芙兰新加坡官网:Sephora新加坡
2018/12/04 全球购物
小饰品店的创业计划书范文
2013/12/28 职场文书
市场部管理制度
2014/02/02 职场文书
电子商务专业毕业生求职信
2014/06/12 职场文书
Springboot配置suffix指定mvc视图的后缀方法
2021/07/03 Java/Android
CSS实现两列布局的N种方法
2021/08/02 HTML / CSS