vue2实现数据请求显示loading图


Posted in Javascript onNovember 28, 2017

一般项目中,有时候会要求,你在数据请求的时候显示一张gif图片,然后数据加载完后,消失。这个,一般只需要在封装的axios中写入js事件即可。当然,我们首先需要在app.vue中,加入此图片。如下:

<template>
 <div id="app">
 <loading v-show="fetchLoading"></loading>
 <router-view></router-view>
 </div>
</template>

<script>
 import { mapGetters } from 'vuex';
 import Loading from './components/common/loading';

 export default {
 name: 'app',
 data() {
 return {
 }
 },
 computed: {
 ...mapGetters([
 'fetchLoading',
 ]),
 },
 components: {
 Loading,
 }
 }
</script>

<style>
 #app{
 width: 100%;
 height: 100%;
 }
</style>

这里的fetchLoading是存在vuex里面的一个变量。在store/modules/common.js里需要如下定义:

/* 此js文件用于存储公用的vuex状态 */
import api from './../../fetch/api'
import * as types from './../types.js'
const state = {
 // 请求数据时加载状态loading
 fetchLoading: false
}
const getters = {
 // 请求数据时加载状态
 fetchLoading: state => state.fetchLoading
}
const actions = {
 // 请求数据时状态loading
 FETCH_LOADING({
 commit
 }, res) {
 commit(types.FETCH_LOADING, res)
 },
}
const mutations = {
 // 请求数据时loading
 [types.FETCH_LOADING] (state, res) {
 state.fetchLoading = res
 }
}

loading组件如下:

<template>
 <div class="loading">
 <img src="./../../assets/main/running.gif" alt="">
 </div>
</template>

<script>
 export default {
 name: 'loading',
 data () {
 return {}
 },
 }
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
 .loading{
 position: fixed;
 top:0;
 left:0;
 z-index:121;
 width: 100%;
 height: 100%;
 background: rgba(0,0,0,0.3);
 display: table-cell;
 vertical-align: middle;
 text-align: center;
 }
 .loading img{
 margin:5rem auto;
 }
</style>

最后在fetch/api.js里封装的axios里写入判断loading事件即可:如下

// axios的请求时间
let axiosDate = new Date()
export function fetch (url, params) {
 return new Promise((resolve, reject) => {
 axios.post(url, params)
 .then(response => {
 // 关闭 loading图片消失
 let oDate = new Date()
 let time = oDate.getTime() - axiosDate.getTime()
 if (time < 500) time = 500
 setTimeout(() => {
  store.dispatch('FETCH_LOADING', false)
 }, time)
 resolve(response.data)
 })
 .catch((error) => {
 // 关闭 loading图片消失
 store.dispatch('FETCH_LOADING', false)
 axiosDate = new Date()
 reject(error)
 })
 })
}
export default {
 // 组件中公共页面请求函数
 commonApi (url, params) {
 if(stringQuery(window.location.href)) {
 store.dispatch('FETCH_LOADING', true);
 }
 axiosDate = new Date();
 return fetch(url, params);
 }
}

这样就实现了,项目中当加载数据的时候,显示gif图片,当数据加载出来时消失。

关于vue.js的学习教程,请大家点击专题vue.js组件学习教程、Vue.js前端组件学习教程进行学习。

更多vue学习教程请阅读专题《vue实战教程》

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

Javascript 相关文章推荐
File文件控件,选中文件(图片,flash,视频)即立即预览显示
Apr 09 Javascript
jQuery extend 的简单实例
Sep 18 Javascript
javascript:void(0)的问题使用探讨
Apr 10 Javascript
原生javascript模仿win8等待提示圆圈进度条
Apr 24 Javascript
JS调用打印机功能简单示例
Nov 28 Javascript
js仿微博动态栏功能
Feb 22 Javascript
BootStrap 动态表单效果
Jun 02 Javascript
json对象及数组键值的深度大小写转换问题详解
Mar 30 Javascript
JavaScript变量声明var,let.const及区别浅析
Apr 23 Javascript
vue-cli的build的文件夹下没有dev-server.js文件配置mock数据的方法
Apr 17 Javascript
vue3实现v-model原理详解
Oct 09 Javascript
ES2020 新特性(种草)
Jan 12 Javascript
Vue2仿淘宝实现省市区三级联动
Apr 15 #Javascript
ligerUI---ListBox(列表框可移动的实例)
Nov 28 #Javascript
基于vue2实现上拉加载功能
Nov 28 #Javascript
微信小程序模板和模块化用法实例分析
Nov 28 #Javascript
基于Vue的移动端图片裁剪组件功能
Nov 28 #Javascript
javaScript canvas实现(画笔大小 颜色 橡皮的实例)
Nov 28 #Javascript
基于Vue框架vux组件库实现上拉刷新功能
Nov 28 #Javascript
You might like
Windows下的PHP5.0安装配制详解
2006/09/05 PHP
在PHP中检查PHP文件是否有语法错误的方法
2009/12/23 PHP
浅谈php冒泡排序
2014/12/30 PHP
PHP获取文件夹内文件数的方法
2015/03/12 PHP
PHP简单实现无限级分类的方法
2016/05/13 PHP
Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)
2017/02/15 PHP
php中pcntl_fork创建子进程的方法实例
2019/03/14 PHP
JavaScript使用prototype定义对象类型(转)[
2006/12/22 Javascript
pjblog中的UBBCode.js
2007/04/25 Javascript
JavaScript对象模型-执行模型
2008/04/28 Javascript
javascript实现的使用方向键控制光标在table单元格中切换
2010/11/17 Javascript
jquery 操作iframe的几种方法总结
2013/12/13 Javascript
js实现新浪微博首页效果
2015/10/16 Javascript
AngularJS 日期格式化详解
2015/12/23 Javascript
AngularJS基础 ng-show 指令简单示例
2016/08/03 Javascript
jQuery获取选中单选按钮radio的值
2016/12/27 Javascript
基于复选框demo(分享)
2017/09/27 Javascript
.vue文件 加scoped 样式不起作用的解决方法
2018/05/28 Javascript
使用webpack3.0配置webpack-dev-server教程
2018/05/29 Javascript
浅析vue 函数配置项watch及函数 $watch 源码分享
2018/11/22 Javascript
vue elementUI table表格数据 滚动懒加载的实现方法
2019/04/04 Javascript
vue添加锚点,实现滚动页面时锚点添加相应的class操作
2020/08/10 Javascript
[38:41]2014 DOTA2国际邀请赛中国区预选赛 LGD VS CNB
2014/05/22 DOTA
Python中的os.path路径模块中的操作方法总结
2016/07/07 Python
python正则实现计算器功能
2017/12/14 Python
pip install urllib2不能安装的解决方法
2018/06/12 Python
Pycharm设置去除显示的波浪线方法
2018/10/28 Python
解决python中画图时x,y轴名称出现中文乱码的问题
2019/01/29 Python
python定时按日期备份MySQL数据并压缩
2019/04/19 Python
python获取点击的坐标画图形的方法
2019/07/09 Python
keras使用Sequence类调用大规模数据集进行训练的实现
2020/06/22 Python
2014年国庆晚会主持词
2014/09/19 职场文书
农业生产宣传标语
2014/10/08 职场文书
2014年音乐教师工作总结
2014/12/03 职场文书
2015年食品安全工作总结
2015/05/15 职场文书
Python中的变量与常量
2021/11/11 Python