vue之项目中如何封装loading加载效果

vue封装loading加载效果

使用两个文件,vue文件是loading加载效果页面,JS文件用于main.js中use,供全局使用

Loading.vue

<template>
 <div v-if="show" class="loading-container">
 <div class="loading-mask"></div>
 <div class="loading-content">
 <div class="loading-animate"></div>
 <!-- <div class="loading-text">{{ text }}</div> -->
 </div>
 </div>
</template>
<script>
export default {
 name: 'Loading',
 props: {
 show: Boolean,
 },
 data() {
 return {
 text: 'loading...',
 }
 },
}
</script>
<style lang="scss" scoped>
.loading-container {
 position: relative;
 z-index: 9999;
 .loading-mask {
 position: fixed;
 top: 0;
 bottom: 0;
 left: 0;
 right: 0;
 background-color: rgba(0, 0, 0, 0.1);
 }
 .loading-content {
 position: fixed;
 left: 50%;
 top: 45%;
 z-index: 300;
 transform: translate(-50%, -45%);
 text-align: center;
 .loading-animate {
 display: inline-block;
 width: 35px;
 height: 35px;
 margin: 25px 0 10px;
 vertical-align: middle;
 animation: cricleLoading 1s steps(12, end) infinite;
 background: transparent
 url('')
 no-repeat;
 background-size: 100%;
 }
 .loading-text {
 font-size: 14px;
 font-weight: 600;
 color: #808085;
 }
 }
}
@-webkit-keyframes cricleLoading {
 0% {
 transform: rotate3d(0, 0, 1, 0deg);
 }
 100% {
 transform: rotate3d(0, 0, 1, 360deg);
 }
}
@keyframes cricleLoading {
 0% {
 transform: rotate3d(0, 0, 1, 0deg);
 }
 100% {
 transform: rotate3d(0, 0, 1, 360deg);
 }
}
</style>

loading.js

import LoadingComponent from '@/components/Loading/loading.vue'

const loading = {
 install: function (Vue) {
 // 创建一个Vue的“子类”组件
 const LoadingConstructor = Vue.extend(LoadingComponent)

 // 创建一个该子类的实例,并挂载到一个元素上
 const instance = new LoadingConstructor()

 // 将这个实例挂载到动态创建的元素上,并将元素添加到全局结构中
 instance.$mount(document.createElement('div'))
 document.body.appendChild(instance.$el)

 // 在Vue的原型链上注册方法,控制组件
 Vue.prototype.$loading = {
 show: () => {
 instance.show = true
 },
 hide: () => {
 instance.show = false
 },
 }
 // 用于window中可以直接使用
 window.$loading = Vue.prototype.$loading
 },
 
 // show: function () {
 // console.log('show')
 // }
}

export default loading

main.js中导入并使用

import Loading from '@/utils/loading'
 Vue.use(Loading)

项目中使用Loading加载

效果就不展示了,直接在项目中使用即可

总结

作者:牛先森家的牛奶原文地址:https://blog.csdn.net/weixin_42681295/article/details/116718300

%s 个评论

要回复文章请先登录注册