加载中 Spin
用于页面和区块的加载中状态
何时使用
- 页面局部处于等待异步数据或正在渲染过程时,合适的加载动效会有效缓解用户的焦虑
基本使用
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
旋转的点
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="spin-dot">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
旋转的线
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="spin-line">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
圆环指示符
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="ring-circle">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
圆环轨道指示符
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="ring-rail">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip
描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip
描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
动态圆环指示符
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="dynamic-circle">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
魔法圆环指示符
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Spin :spinning="spinning" indicator="magic-ring">
<p class="spin-content">
当 spinning 为 false 时,不显示 loading 状态;当 spinning 为 true 时,显示 loading 效果;如果不设置 tip 描述文案时,则只有 loading 效果水平垂直居中;如果设置了 tip 描述文案,则 loading 效果和 tip 描述文案一起水平垂直居中。
</p>
</Spin>
</template>
<style lang="less" scoped>
.spin-content {
display: inline-block;
border: 1px solid #91d5ff;
border-radius: 6px;
background-color: #e6f7ff;
padding: 16px;
}
</style>
各种大小
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
</script>
<template>
<Space vertical>
<Space>
<Spin class="u-spin" :spinning="spinning" size="small" />
<Spin class="u-spin" :spinning="spinning" />
<Spin class="u-spin" :spinning="spinning" size="large" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="spin-dot" />
<Spin class="u-spin" :spinning="spinning" indicator="spin-dot" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="spin-dot" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="spin-line" />
<Spin class="u-spin" :spinning="spinning" indicator="spin-line" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="spin-line" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="ring-circle" />
<Spin class="u-spin" :spinning="spinning" indicator="ring-circle" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="ring-circle" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="ring-rail" />
<Spin class="u-spin" :spinning="spinning" indicator="ring-rail" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="ring-rail" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="dynamic-circle" />
<Spin class="u-spin" :spinning="spinning" indicator="dynamic-circle" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="dynamic-circle" />
<Spin class="u-spin" :spinning="spinning" size="small" indicator="magic-ring" />
<Spin class="u-spin" :spinning="spinning" indicator="magic-ring" />
<Spin class="u-spin" :spinning="spinning" size="large" indicator="magic-ring" />
</Space>
</Space>
</template>
<style lang="less" scoped>
.u-spin {
width: 100px !important;
height: 100px !important;
}
</style>
自定义描述文案
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
const sizeOptions = [
{
label: 'small',
value: 'small'
},
{
label: 'middle',
value: 'middle'
},
{
label: 'large',
value: 'large'
}
]
const size = ref('middle')
</script>
<template>
<Space vertical>
<Radio :options="sizeOptions" v-model:value="size" button button-style="solid" />
<Space>
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" />
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" indicator="spin-dot" />
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" indicator="spin-line" />
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" indicator="ring-circle" />
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" indicator="ring-rail" />
<Spin class="u-spin" :size="size" tip="加载中..." :spinning="spinning" indicator="dynamic-circle" />
<Spin class="u-spin" :size="size" :spinning="spinning" indicator="magic-ring">
<template #tip>加载中...</template>
</Spin>
</Space>
</Space>
</template>
<style lang="less" scoped>
.u-spin {
width: 100px !important;
height: 100px !important;
}
</style>
自定义样式
Show Code
<script setup lang="ts">
import { ref } from 'vue'
const spinning = ref(true)
const sizeOptions = [
{
label: 'small',
value: 'small'
},
{
label: 'middle',
value: 'middle'
},
{
label: 'large',
value: 'large'
}
]
const size = ref('middle')
</script>
<template>
<Space vertical>
<Radio :options="sizeOptions" v-model:value="size" button button-style="solid" />
<Space>
<Spin class="u-spin" :size="size" color="#fadb14" :spinning="spinning" />
<Spin class="u-spin" :size="size" color="#fadb14" :spinning="spinning" indicator="spin-dot" />
<Spin class="u-spin" :size="size" color="#fadb14" :spinning="spinning" indicator="spin-line" />
<Spin class="u-spin" :size="size" color="#fadb14" :spinning="spinning" :spin-circle-percent="50" indicator="ring-circle" />
<Spin
class="u-spin"
:size="size"
color="#fadb14"
:spin-circle-percent="50"
ring-rail-color="rgba(212, 136, 6, 0.6)"
:spinning="spinning"
indicator="ring-rail"
/>
<Spin class="u-spin" :size="size" color="#fadb14" :spinning="spinning" indicator="dynamic-circle" />
<Spin class="u-spin" :size="size" color="#fadb14" magic-ring-color="#ffe58f" :spinning="spinning" indicator="magic-ring" />
</Space>
</Space>
</template>
<style lang="less" scoped>
.u-spin {
width: 100px !important;
height: 100px !important;
}
</style>
APIs
Spin
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
spinning | 是否为加载中状态 | boolean | true |
size | 加载中尺寸 | 'small' | 'middle' | 'large' | 'middle' |
tip | 描述文案 | string | slot | undefined |
indicator | 加载指示符 | 'dot' | 'spin-dot' | 'spin-line' | 'ring-circle' | 'ring-rail' | 'dynamic-circle' | 'magic-ring' | 'dot' |
color | 指示符颜色,当 indicator: 'magic-ring' 时为外环颜色 | string | '#1677ff' |
spinCircleWidth | 圆环宽度,单位是加载指示符宽度的百分比,仅当 indicator: 'ring-circle' | 'ring-rail' 时生效 | number | 12 |
spinCirclePercent | 圆环长度百分比 (0~100 ),单位是圆环周长的百分比,仅当 indicator: 'ring-circle' | 'ring-rail' 时生效 | number | 33 |
ringRailColor | 圆环轨道颜色,仅当 indicator: 'ring-rail' 时生效 | string | 'rgba(0, 0, 0, 0.12)' |
magicRingColor | 内环颜色,仅当 indicator: 'magic-ring' 时生效 | string | '#4096ff' |
rotate | spin-dot 或 spin-line 初始是否旋转,仅当 indicator: 'spin-dot' | 'spin-line' 时生效 | boolean | false |
speed | spin-dot 或 spin-line 渐变旋转的动画速度,单位 ms ,仅当 indicator: 'spin-dot' | 'spin-line' 时生效 | number | 800 |
Slots
名称 | 说明 | 类型 |
---|---|---|
tip | 自定义描述文案 | v-slot:tip |
default | 自定义内容 | v-slot:default |