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 相关文章推荐
jquery高级编程的最佳实践详解
Mar 23 Javascript
dreamweaver 8实现Jquery自动提示
Dec 04 Javascript
jquery Validation表单验证使用详解
Sep 12 Javascript
jQuery实现仿百度帖吧头部固定导航效果
Aug 07 Javascript
Bootstrap字体图标无法正常显示的解决方法
Oct 08 Javascript
jQuery插件ajaxFileUpload异步上传文件
Oct 19 Javascript
require.js+vue开发微信上传图片组件
Oct 27 Javascript
AngularJS实现动态编译添加到dom中的方法
Nov 04 Javascript
AngularJS解决ng-if中的ng-model值无效的问题
Jun 21 Javascript
React事件处理的机制及原理
Dec 03 Javascript
详解vue-cli+element-ui树形表格(多级表格折腾小计)
Apr 17 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
Jun 14 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新手上路(十二)
2006/10/09 PHP
PHP+jQuery实现自动补全功能源码
2013/05/15 PHP
php arsort 数组降序排序详细介绍
2016/11/17 PHP
thinkPHP5框架闭包函数与子查询传参用法示例
2018/08/02 PHP
one.php 多项目、函数库、类库 统一为一个版本的方法
2020/08/24 PHP
Expandable &quot;Detail&quot; Table Rows
2007/08/29 Javascript
JS下高效拼装字符串的几种方法比较与测试代码
2010/04/15 Javascript
jquery select多选框的左右移动 具体实现代码
2013/07/03 Javascript
javascript中比较字符串是否相等的方法
2013/07/23 Javascript
javascript与有限状态机详解
2014/05/08 Javascript
webapp框架AngularUI的demo改造之路
2014/12/21 Javascript
javascript动态添加删除tabs标签的方法
2015/07/06 Javascript
nodejs个人博客开发第三步 载入页面
2017/04/12 NodeJs
Angular2自定义分页组件
2017/04/19 Javascript
Vuex之理解Getters的用法实例
2017/04/19 Javascript
vue中用H5实现文件上传的方法实例代码
2017/05/27 Javascript
Vue渲染函数详解
2017/09/15 Javascript
js继承的这6种方式!(上)
2019/04/23 Javascript
vue 实现websocket发送消息并实时接收消息
2019/12/09 Javascript
Vue 使用typescript如何优雅的调用swagger API
2020/09/01 Javascript
JavaScript实现网页留言板功能
2020/11/23 Javascript
Python使用新浪微博API发送微博的例子
2014/04/10 Python
Python 中开发pattern的string模板(template) 实例详解
2017/04/01 Python
在python中pandas读文件,有中文字符的方法
2018/12/12 Python
python三引号输出方法
2019/02/27 Python
pandas DataFrame行或列的删除方法的实现示例
2019/08/02 Python
Pytorch之finetune使用详解
2020/01/18 Python
你应该知道的30个css选择器
2014/03/19 HTML / CSS
理肤泉俄罗斯官网:La Roche-Posay俄罗斯
2018/07/24 全球购物
杭州龙健科技笔试题.net部分笔试题
2016/01/24 面试题
十佳护士获奖感言
2014/02/18 职场文书
我爱我的祖国演讲稿
2014/05/04 职场文书
幼儿园辞职信
2015/05/13 职场文书
2015军训通讯稿大全
2015/07/18 职场文书
MySQL中int (10) 和 int (11) 的区别
2022/01/22 MySQL
Golang 链表的学习和使用
2022/04/19 Golang