diff options
| author | Mistivia <i@mistivia.com> | 2025-02-10 23:21:24 +0800 |
|---|---|---|
| committer | Mistivia <i@mistivia.com> | 2025-02-10 23:21:24 +0800 |
| commit | 39c98aef0b1077001571a11adfd6b4c80dec256a (patch) | |
| tree | 495455d698594b7f3fa0dcf7be39b7e549eedf28 /src/components/Loading.svelte | |
| parent | 45337902f925e8d826aae5a2347029ab03753113 (diff) | |
add loading page
Diffstat (limited to 'src/components/Loading.svelte')
| -rw-r--r-- | src/components/Loading.svelte | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/components/Loading.svelte b/src/components/Loading.svelte new file mode 100644 index 0000000..5fb6f9a --- /dev/null +++ b/src/components/Loading.svelte @@ -0,0 +1,52 @@ +<script> + import { isLoading } from '../control/loading'; +</script> + +{#if $isLoading} + <div id="loading"> + <div class="loading-content"> + <div class="loading-spinner"></div> + <br> + <p>加载中...</p> + </div> + </div> +{/if} + + +<style> + /* 全屏 loading 样式 */ + #loading { + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: rgba(255, 255, 255, 0.9); /* 半透明背景 */ + z-index: 9999; /* 确保在最前面 */ + display: block; /* 默认隐藏 */ + } + + /* loading 内容区域 */ + .loading-content { + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + text-align: center; + } + + /* loading 动画 */ + .loading-spinner { + width: 50px; + height: 50px; + border: 5px solid #f3f3f3; + border-top: 5px solid #3498db; + border-radius: 50%; + animation: spin 1s linear infinite; + } + + @keyframes spin { + 0% { transform: rotate(0deg); } + 100% { transform: rotate(360deg); } + } +</style> |
