vue 项目中使用Loading组件的示例代码
什么是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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。