自定义加载中的loading组件

tech2026-01-20  4

自定义加载中的loading组件

components / loading.vue页面

<template> <div class="loading-container" v-if="showWrap" :class="showContent ?'fadein':'fadeout'"> <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: '正在加载...' } } } </script> <style lang="less" scoped> .loading-container { position: relative; text-align: center; .loading-mask { width: 300px; height: 300px; position: fixed; top: 35%; background-color: rgba(0, 0, 0, 0.7); left: 30%; border-radius: 20px; background-color: rgba(0, 0, 0, 0.7); } .loading-content { position: fixed; left: 50%; top: 45%; z-index: 300; transform: translate(-50%, -45%); text-align: center; color: #fff; .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; color: #fff; } } } .fadein { animation: cricleLoading 0.25s; } .fadeout { animation: cricleLoading 0.25s; opacity: 0; } @-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>

src / lib / loading.js页面

import vue from 'vue' import loadingComponent from '../components/loading' const ToastConstructor = vue.extend(loadingComponent) function showToast (text, duration = 2000) { const toastDom = new ToastConstructor({ el: document.createElement('div'), data () { return { text: text, showWrap: true, // 是否显示组件 showContent: true // 作用:在隐藏组件之前,显示隐藏动画 } } }) document.body.appendChild(toastDom.$el) setTimeout(() => { toastDom.showContent = false }, duration - 1250) setTimeout(() => { toastDom.showWrap = false }, duration) } function registryToast () { vue.prototype.$toast = showToast } export default registryToast

在main.js中引入:

import loading from './lib/loading' // 引入loading Vue.use(loading) // 全局使用loading

使用方法:

this.$toast('查询支付结果', 3000)
最新回复(0)