旋转器
使用 Bootstrap 旋转器指示组件或页面的加载状态,这些旋转器完全由 HTML、CSS 构建,且不使用 JavaScript。
关于
Bootstrap “旋转器”可用于在项目中显示加载状态。它们仅使用 HTML 和 CSS 构建,这意味着您无需任何 JavaScript 即可创建它们。但是,您需要一些自定义 JavaScript 来切换它们的可见性。它们的外观、对齐方式和大小可以使用我们出色的实用程序类轻松自定义。
出于可访问性目的,此处的每个加载器都包含 role="status"
和嵌套的 <span class="visually-hidden">Loading...</span>
。
prefers-reduced-motion
媒体查询。请参阅 无障碍文档的减少运动部分。
边框旋转器
使用边框旋转器作为轻量级加载指示器。
<div class="spinner-border" role="status">
<span class="visually-hidden">Loading...</span>
</div>
颜色
边框旋转器使用 currentColor
作为其 border-color
,这意味着您可以使用 文本颜色实用程序 自定义颜色。您可以在标准旋转器上使用我们任何的文本颜色实用程序。
<div class="spinner-border text-primary" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-secondary" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-success" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-danger" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-warning" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-info" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-light" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-border text-dark" role="status">
<span class="visually-hidden">Loading...</span>
</div>
border-color
实用程序?每个边框旋转器至少为一侧指定一个 transparent
边框,因此 .border-{color}
实用程序将覆盖它。
增长旋转器
如果您不喜欢边框旋转器,请切换到增长旋转器。虽然它在技术上没有旋转,但它确实会重复增长!
<div class="spinner-grow" role="status">
<span class="visually-hidden">Loading...</span>
</div>
同样,此旋转器使用 currentColor
构建,因此您可以使用 文本颜色实用程序 轻松更改其外观。以下是蓝色,以及支持的变体。
<div class="spinner-grow text-primary" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-secondary" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-success" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-danger" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-warning" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-info" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-light" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow text-dark" role="status">
<span class="visually-hidden">Loading...</span>
</div>
对齐
Bootstrap 中的加载指示器使用 rem
、currentColor
和 display: inline-flex
构建。这意味着它们可以轻松调整大小、重新着色并快速对齐。
边距
使用 边距实用工具,如 .m-5
,轻松实现间距。
<div class="spinner-border m-5" role="status">
<span class="visually-hidden">Loading...</span>
</div>
放置
使用 flexbox 实用工具、float 实用工具 或 文本对齐 实用工具,在任何情况下将加载指示器准确地放置在您需要的位置。
Flex
<div class="d-flex justify-content-center">
<div class="spinner-border" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
<div class="d-flex align-items-center">
<strong role="status">Loading...</strong>
<div class="spinner-border ms-auto" aria-hidden="true"></div>
</div>
浮动
<div class="clearfix">
<div class="spinner-border float-end" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
文本对齐
<div class="text-center">
<div class="spinner-border" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
大小
添加 .spinner-border-sm
和 .spinner-grow-sm
以生成一个较小的加载指示器,可以在其他组件中快速使用。
<div class="spinner-border spinner-border-sm" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow spinner-grow-sm" role="status">
<span class="visually-hidden">Loading...</span>
</div>
或者,根据需要使用自定义 CSS 或内联样式来更改尺寸。
<div class="spinner-border" style="width: 3rem; height: 3rem;" role="status">
<span class="visually-hidden">Loading...</span>
</div>
<div class="spinner-grow" style="width: 3rem; height: 3rem;" role="status">
<span class="visually-hidden">Loading...</span>
</div>
按钮
在按钮中使用加载指示器以指示当前正在处理或进行操作。您还可以将文本从加载指示器元素中交换出来,并根据需要使用按钮文本。
<button class="btn btn-primary" type="button" disabled>
<span class="spinner-border spinner-border-sm" aria-hidden="true"></span>
<span class="visually-hidden" role="status">Loading...</span>
</button>
<button class="btn btn-primary" type="button" disabled>
<span class="spinner-border spinner-border-sm" aria-hidden="true"></span>
<span role="status">Loading...</span>
</button>
<button class="btn btn-primary" type="button" disabled>
<span class="spinner-grow spinner-grow-sm" aria-hidden="true"></span>
<span class="visually-hidden" role="status">Loading...</span>
</button>
<button class="btn btn-primary" type="button" disabled>
<span class="spinner-grow spinner-grow-sm" aria-hidden="true"></span>
<span role="status">Loading...</span>
</button>
CSS
变量
在 v5.2.0 中添加作为 Bootstrap 不断发展的 CSS 变量方法的一部分,加载指示器现在在 .spinner-border
和 .spinner-grow
上使用本地 CSS 变量,以增强实时自定义。CSS 变量的值通过 Sass 设置,因此 Sass 自定义仍然受支持。
边框加载指示器变量
--#{$prefix}spinner-width: #{$spinner-width};
--#{$prefix}spinner-height: #{$spinner-height};
--#{$prefix}spinner-vertical-align: #{$spinner-vertical-align};
--#{$prefix}spinner-border-width: #{$spinner-border-width};
--#{$prefix}spinner-animation-speed: #{$spinner-animation-speed};
--#{$prefix}spinner-animation-name: spinner-border;
增长 spinner 变量
--#{$prefix}spinner-width: #{$spinner-width};
--#{$prefix}spinner-height: #{$spinner-height};
--#{$prefix}spinner-vertical-align: #{$spinner-vertical-align};
--#{$prefix}spinner-animation-speed: #{$spinner-animation-speed};
--#{$prefix}spinner-animation-name: spinner-grow;
对于两个 spinner,小 spinner 修改器类用于根据需要更新这些 CSS 变量的值。例如,.spinner-border-sm
类执行以下操作
--#{$prefix}spinner-width: #{$spinner-width-sm};
--#{$prefix}spinner-height: #{$spinner-height-sm};
--#{$prefix}spinner-border-width: #{$spinner-border-width-sm};
Sass 变量
$spinner-width: 2rem;
$spinner-height: $spinner-width;
$spinner-vertical-align: -.125em;
$spinner-border-width: .25em;
$spinner-animation-speed: .75s;
$spinner-width-sm: 1rem;
$spinner-height-sm: $spinner-width-sm;
$spinner-border-width-sm: .2em;
关键帧
用于为我们的 spinner 创建 CSS 动画。包含在 scss/_spinners.scss
中。
@keyframes spinner-border {
to { transform: rotate(360deg) #{"/* rtl:ignore */"}; }
}
@keyframes spinner-grow {
0% {
transform: scale(0);
}
50% {
opacity: 1;
transform: none;
}
}