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 相关文章推荐
OfflineSave离线保存代码再次发布使用说明
May 23 Javascript
javascript倒计时功能实现代码
Jun 07 Javascript
javascript函数定义的几种区别小结
Jan 06 Javascript
jquery代码实现多选、不同分享功能
Jul 31 Javascript
基于Jquery实现焦点图淡出淡入效果
Nov 30 Javascript
html5+javascript实现简单上传的注意细节
Apr 18 Javascript
webpack中引用jquery的简单实现
Jun 08 Javascript
jQuery+CSS实现简单切换菜单示例
Jul 27 Javascript
chrome浏览器如何断点调试异步加载的JS
Sep 05 Javascript
JavaScript基于自定义函数判断变量类型的实现方法
Nov 23 Javascript
浅谈微信小程序flex布局基础
Sep 10 Javascript
vue实现分页加载效果
Dec 24 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
php之字符串变相相减的代码
2007/03/19 PHP
PHP手机号中间四位用星号*代替显示的实例
2017/06/02 PHP
OfflineSave离线保存代码再次发布使用说明
2007/05/23 Javascript
用CSS+JS实现的进度条效果效果
2007/06/05 Javascript
jQuery Jcrop插件实现图片选取功能
2011/11/23 Javascript
JavaScript异步调用定时方法并停止该方法实现代码
2012/03/16 Javascript
兼容主流浏览器的jQuery+CSS 实现遮罩层的简单代码
2014/10/14 Javascript
跟我学习javascript解决异步编程异常方案
2015/11/23 Javascript
详解js中构造流程图的核心技术JsPlumb(2)
2015/12/08 Javascript
用jQuery获取table中行id和td值的实现代码
2016/05/19 Javascript
深入理解JQuery循环绑定事件
2016/06/02 Javascript
jquery中live()方法和bind()方法区别分析
2016/06/23 Javascript
Ajax使用原生态JS验证用户名是否存在
2020/05/26 Javascript
bootstrap学习使用(导航条、下拉菜单、轮播、栅格布局等)
2016/12/01 Javascript
canvas知识总结
2017/01/25 Javascript
NodeJS、NPM安装配置步骤(windows版本) 以及环境变量详解
2017/05/13 NodeJs
JavaScript之排序函数_动力节点Java学院整理
2017/06/30 Javascript
jQuery实现文字超过1行、2行或规定的行数时自动加省略号的方法
2018/03/28 jQuery
JavaScript中concat复制数组方法浅析
2019/01/20 Javascript
vue引入微信sdk 实现分享朋友圈获取地理位置功能
2019/07/04 Javascript
VUE 组件转换为微信小程序组件的方法
2019/11/06 Javascript
Vue解析带html标签的字符串为dom的实例
2019/11/13 Javascript
[原创]Python入门教程2. 字符串基本操作【运算、格式化输出、常用函数】
2018/10/29 Python
Python判断对象是否为文件对象(file object)的三种方法示例
2019/04/26 Python
对python中的控制条件、循环和跳出详解
2019/06/24 Python
python多线程案例之多任务copy文件完整实例
2019/10/29 Python
python使用pyecharts库画地图数据可视化的实现
2020/03/25 Python
Python .py生成.pyd文件并打包.exe 的注意事项说明
2021/03/04 Python
AMAVII眼镜官网:时尚和设计师太阳镜
2019/05/05 全球购物
日本最大的购物网站:日本乐天市场(Rakuten Ichiba)
2020/11/04 全球购物
合作意向书模板
2014/03/31 职场文书
财务工作失误检讨书
2015/02/19 职场文书
反腐倡廉影片观后感
2015/06/08 职场文书
2015年行政管理人员工作总结
2015/10/15 职场文书
baselines示例程序train_cartpole.py的ImportError
2022/05/20 Python
Java实现HTML转为Word的示例代码
2022/06/28 Java/Android