什么是vue插件"htmlcode">
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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]