Indicate the loading state of a component or page with Bootstrap spinners, built entirely with HTML, CSS, and no JavaScript.
Their appearance, alignment, and sizing can be easily customized with our amazing utility classes.
Use the border spinners for a lightweight loading indicator.
<template>
<Spinner />
</template>
The border spinner uses text-color
attribute for its Spinner
component, meaning you can customize the color with text color utilities
.
You can use any of our text color utilities on the standard spinner.
<template>
<Spinner text-color="primary" />
<Spinner text-color="secondary" />
<Spinner text-color="success" />
<Spinner text-color="danger" />
<Spinner text-color="warning" />
<Spinner text-color="info" />
<Spinner text-color="light" />
<Spinner text-color="dark" />
</template>
If you don't fancy a border spinner, switch to the grow spinner. While it doesn't technically spin, it does repeatedly grow!
<template>
<Spinner spinner="grow" />
</template>
Once again, this spinner is built with text-color
, so you can easily change its appearance with [text color utilities][color]. Here it is in blue, along with the supported variants.
<template>
<Spinner
spinner="grow"
text-color="primary"
/>
<Spinner
spinner="grow"
text-color="secondary"
/>
<Spinner
spinner="grow"
text-color="success"
/>
<Spinner
spinner="grow"
text-color="danger"
/>
<Spinner
spinner="grow"
text-color="warning"
/>
<Spinner
spinner="grow"
text-color="info"
/>
<Spinner
spinner="grow"
text-color="light"
/>
<Spinner
spinner="grow"
text-color="dark"
/>
</template>
Spinners in Bootstrap are built with rem
s, text-color
, and display: inline-flex
.
This means they can easily be resized, recolored, and quickly aligned.
Use margin utilities
like mergin="5"
for easy spacing.
<template>
<Spinner :mergin="5" />
</template>
Use flexbox utilities
, float utilites
, or text alignment
utilities to place spinners exactly where you need them in any situation.
<template>
<b-div
flex
justify-content="center"
>
<Spinner>
<b-span visually-hidden>
Loading...
</b-span>
</Spinner>
</b-div>
</template>
<template>
<b-div
flex
align-items="center"
>
<strong>Loading...</strong>
<Spinner
aria-hidden="true"
margin="s-auto"
/>
</b-div>
</template>
<template>
<b-div clearfix>
<Spinner float="end" />
</b-div>
</template>
<template>
<b-div text-alignment="center">
<Spinner />
</b-div>
</template>
Add sm
attribute to make a smaller spinner that can quickly be used within other components.
<template>
<Spinner sm />
<Spinner
spinner="grow"
sm
/>
</template>
Or, use custom CSS or inline styles to change the dimensions as needed.
<template>
<Spinner style="width: 3rem; height: 3rem" />
<Spinner
spinner="grow"
style="width: 3rem; height: 3rem"
/>
</template>
Use spinners within buttons to indicate an action is currently processing or taking place. You may also swap the text out of the spinner element and utilize button text as needed.
<template>
<b-button
button="primary"
disabled
>
<Spinner
sm
aria-hidden="true"
/>
</b-button>
<b-button
button="primary"
disabled
>
<Spinner
sm
aria-hidden="true"
/>
Loading...
</b-button>
</template>
<template>
<b-button
button="primary"
disabled
>
<Spinner
spinner="grow"
sm
aria-hidden="true"
/>
</b-button>
<b-button
button="primary"
disabled
>
<Spinner
spinner="grow"
sm
aria-hidden="true"
/>
Loading...
</b-button>
</template>