vue 项目中使用Loading组件的示例代码


Posted in Javascript onAugust 31, 2018

什么是vue插件?

从功能上说,插件是为Vue添加全局功能的一种机制,比如给Vue添加一个全局组件,全局指令等;

从代码结构上说,插件就是一个必须拥有install方法的对象,这个方法的接收的第一个参数是Vue构造函数,还可以接收一个可选的参数,用于配置插件:

var myplugin = {
install:function(Vue, options){
...
}
}

从意义上来说,正如jQuery的$.fn使jQuery有了一个庞大的生态一样,Vue的插件机制使Vue形成了一个生态系统,你可以开发一个插件给别人复用。

当在vue项目中请求后台接口时,常常会使用 loding 过渡数据的加载时间。

如果 loading 作为一个全局的加载状态,应该写在项目中的App.vue中

<template>
  <div id="app">
    <router-view></router-view>
    <loading v-if='LOADING'/> //自己封装的loading 组件
  </div>
</template>

<script>
  export default {
    name: 'App'
  }
</script>

这个Loading 组件通过 LOADING 的状态显示隐藏。我们希望在请求某个接口的时候,将 LOADING 改为true,当接口请求后改为false,这样就能实现loading的过渡效果了。

但是这里有一个问题,loading组件的显示和隐藏是通过 LOADING 来控制的, 如果将 LOADING 直接定义在 App.vue 中,每次请求中直接修改 LOADING 是很麻烦的,所以推荐使用 vuex

第一步:按照官网的例子,在App.vue的同层目录下新建一个 store.js 文件.

// store.js
const store = new Vuex.Store({
  state: {
    LOADING: false
  },
  mutations: {
    showLoading(state){
      state.LOADING = true  
    },
    hideLoading (state) {
      state.LOADING = false
    }
  }
})

第二步: 在 main.js 中引入 store.js,并挂载到 Vue 实列上

import store from './store'

new Vue({
  el: '#app',
  store,
  template: '<App/>',
  components: { App }
})

第三步,在请求中改变 LOADING 的状态

Vue 项目中 API 的请求方法有很多,如果项目比较简单,数据量比较小,可以在在页面中直接使用像 axios、ajax、request等的 post/get 请求。以 axios 为例:

methods:{
  //通常请求都希望以异步的方式,方便数据操作
  async test(){
    this.$store.commit('showLoading')
    //这里需要将 axios 提前挂载到 Vue的属性上。
    await this.$axios.get('xxx/xxxx/xxx')
    this.$store.commit('hideLoading')
  }
}

第四步: 监听 LOADING 状态

Vuex 中 state 是动态更新的,也就是不管在任何地方对某一个 state的值做了修改,那么依赖该数据的 DOM 也将会发生改变。修改 App.vue 文件,监听 LOADING 的值的变化。

<template>
  <div id="app">
    <router-view></router-view>
    <loading v-if='LOADING'/> //自己封装的loading 组件
  </div>
</template>

<script>
  import {mapState} from 'vuex'

  export default {
    computed:{
      ...mapState([
        'LOADING'
      ])
    },
    name: 'App'
  }
</script>

总结:

loading的过渡效果最根本的就是通过 state 来控制 loading 组件的显示和隐藏。在请求接口前使该状态为 为 true,接口完成后改为 false。

简单的 loading 组件

一个简单的 loading 组件,应该会有一个遮罩层,一个过度动画,或者一个loading 说明。

<template>
  <section>
    <div class='mock'>
      <div class='main'>
        loading...
      </div>
    </div>
  </section>
</template>  
<style>
  section{
    width:100vh;
    height:100vh;
    position:relative;
  }
  .mock{
    tion{
    width:100vh;
    height:100vh;
    position:absolute;
     z-index:100;
    background-color:#abb2bf;
  }
  .main{
    margin:200px auto;
    text-align:center:
  }
</style>

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

Javascript 相关文章推荐
JS类定义原型方法的两种实现的区别评论很多
Sep 12 Javascript
JavaScript 基础知识 被自己遗忘的
Oct 15 Javascript
让input框实现类似百度的搜索提示(基于jquery事件监听)
Jan 31 Javascript
JavaScript实现获取某个元素相邻兄弟节点的prev与next方法
Jan 25 Javascript
Angular将填入表单的数据渲染到表格的方法
Sep 22 Javascript
微信小程序日期时间选择器使用方法
Feb 01 Javascript
webpack4+Vue搭建自己的Vue-cli项目过程分享
Aug 29 Javascript
VUE预渲染及遇到的坑
Sep 03 Javascript
JavaScript遍历DOM元素的常见方式示例
Feb 16 Javascript
微信小程序使用canvas自适应屏幕画海报并保存图片功能
Jul 25 Javascript
vue-socket.io跨域问题有效解决方法
Feb 11 Javascript
JavaScript实现一键复制内容剪贴板
Jul 23 Javascript
解决Angular2 router.navigate刷新页面的问题
Aug 31 #Javascript
浅谈angularJS2中的界面跳转方法
Aug 31 #Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
Aug 31 #Javascript
Angular2之二级路由详解
Aug 31 #Javascript
基于jQuery ztree实现表格风格的树状结构
Aug 31 #jQuery
详解Vue CLI3配置之filenameHashing使用和源码设计使用和源码设计
Aug 31 #Javascript
Bootstrap Table 双击、单击行获取该行及全表内容
Aug 31 #Javascript
You might like
一些花式咖啡的配方
2021/03/03 冲泡冲煮
用PHP生成html分页列表的代码
2007/03/18 PHP
PHP 字符串 小常识
2009/06/05 PHP
关于php支持的协议与封装协议总结(推荐)
2017/11/17 PHP
laravel实现图片上传预览,及编辑时可更换图片,并实时变化的例子
2019/11/14 PHP
深入理解JavaScript作用域和作用域链
2011/10/21 Javascript
A标签触发onclick事件而不跳转的多种解决方法
2013/06/27 Javascript
JS保存和删除cookie操作 判断cookie是否存在
2013/11/13 Javascript
js实现遮罩层划出效果是生成div而不是显示
2014/07/29 Javascript
jQuery验证插件 Validate详解
2014/11/20 Javascript
jQuery实现为控件添加水印文字效果(附源码)
2015/12/02 Javascript
实例剖析AngularJS框架中数据的双向绑定运用
2016/03/04 Javascript
jQuery简单创建节点的方法
2016/09/09 Javascript
微信小程序 倒计时组件实现代码
2016/10/24 Javascript
JavaScript实现简单动态进度条效果
2018/04/06 Javascript
详解vue-router传参的两种方式
2018/09/10 Javascript
antd组件Upload实现自己上传的实现示例
2018/12/18 Javascript
layui-table表复选框勾选的所有行数据获取的例子
2019/09/13 Javascript
vue实现简单计算商品价格
2020/09/14 Javascript
js canvas实现俄罗斯方块
2020/10/11 Javascript
[32:56]完美世界DOTA2联赛PWL S3 Rebirth vs CPG 第二场 12.11
2020/12/16 DOTA
Python实现 多进程导入CSV数据到 MySQL
2017/02/26 Python
python中Pycharm 输出中文或打印中文乱码现象的解决办法
2017/06/16 Python
Django 多表关联 存储 使用方法详解 ManyToManyField save
2019/08/09 Python
解决python有时候import不了当前的包问题
2019/08/28 Python
解决tensorflow训练时内存持续增加并占满的问题
2020/01/19 Python
基于python代码批量处理图片resize
2020/06/04 Python
css3 伪类选择器快速复习小结
2019/09/10 HTML / CSS
澳大利亚排名第一的露营和户外设备在线零售商:Outbax
2020/05/06 全球购物
分解成质因数(如435234=251*17*17*3*2,据说是华为笔试题)
2014/07/16 面试题
公司领导班子群众路线四风问题对照检查材料
2014/10/02 职场文书
员工离职感谢信
2015/01/22 职场文书
嘉宾邀请函
2015/01/31 职场文书
2015年度员工自我评价范文
2015/03/11 职场文书
Python 如何解决稀疏矩阵运算
2021/05/26 Python
Python编程源码报错解决方法总结经验分享
2021/10/05 Python