LoadingSpinner.vue 1.52 KB
<template>
  <div class="loading-spinner" :class="{ 'loading-overlay': overlay }">
    <div class="spinner-container">
      <div class="spinner" :style="{ width: size + 'px', height: size + 'px' }">
        <div class="spinner-inner" :style="{ borderColor: color }"></div>
      </div>
      <p v-if="text" class="loading-text" :style="{ color: textColor }">{{ text }}</p>
    </div>
  </div>
</template>

<script setup>
defineProps({
  // 是否显示遮罩层
  overlay: {
    type: Boolean,
    default: false
  },
  // 加载器大小
  size: {
    type: Number,
    default: 40
  },
  // 加载器颜色
  color: {
    type: String,
    default: '#1989fa'
  },
  // 加载文本
  text: {
    type: String,
    default: ''
  },
  // 文本颜色
  textColor: {
    type: String,
    default: '#969799'
  }
})
</script>

<style scoped>
.loading-spinner {
  display: flex;
  align-items: center;
  justify-content: center;
}

.loading-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  z-index: 9999;
}

.spinner-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.spinner {
  position: relative;
}

.spinner-inner {
  width: 100%;
  height: 100%;
  border: 3px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.loading-text {
  font-size: 14px;
  margin: 0;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
</style>