Skeleton
Placeholder while you wait for content to load, or to visualise content that doesn't exist yet.
Import#
import { Skeleton, SkeletonText, SkeletonCircle } from '@volue/wave-react';// you may also access skeletonDisplay util function// import { skeletonDisplay } from '@volue/wave-react';
Background#
Skeletons provide an alternative to the Spinner component. Rather than showing an abstract widget, they are used in place of content being loaded creating anticipation of what is to come.
Skeletons improve perceived performance, which tends to improve user experience by reducing load time frustration and making the page feel more responsive.
Examples#
Basic#
The default Skeleton renders rectangular block.
The width will be 100% unless a different width is specified. A standalone Skeleton that doesn't wrap any content, inserts a zero-width space character so by default it will have the same height as a single line of text by adopting the line-height. You should use the height prop to change the height of the Skeleton.
Text#
SkeletonText can be used to represent a line or multiple lines of text. Useful for rendering a placeholder for text content such as paragraphs.
SkeletonText has rounded corners and provides control of content length. Use lines property to simulate size of loaded content.
Last line is visually shorter than others.
Height of SkeletonText is the same height as a single line of text unless an explicit height is specified. This allows for inheriting the size of text from a parent element.
Circle#
SkeletonCircle renders a circular skeleton. Useful as a placeholder for graphic elements such as icons, avatars and circular images. Use size property to adjust the size.
Content wrapping#
When part of the content is known you don't have to use standalone Skeleton components. In these instances, you can pass children and the Skeleton component will infer its size from them.
When Skeleton, SkeletonText or SkeletonCircle has content wrapped inside, width is automatically defined by that content thanks to the width: fit-content CSS rule.
Loaded state#
Use isLoaded property to reveal content wrapped inside the Skeleton.
Alternatively use standard conditional rendering to render skeleton placeholder or content.
Complex example#
Without animation#
You can disable the animation by setting animation prop to false. This is useful when you want to use Skeleton as a static placeholder without any loading effect.
Display scopes#
Use the skeletonDisplay utility to control the animation of multiple Skeleton components at once. It generates a CSS class to apply to a parent element, cascading the animation settings to all descendant skeletons. This is useful for disabling animations on a group of skeletons without passing animation={false} to each one.
import { skeletonDisplay } from '@volue/wave-react';
Accessibility features#
- The animation can be disabled by enabling the prefers-reduced-motionsetting at the OS level.
- Skeleton Loader has the aria-busyattribute set to true by default to indicate that the content is loading.
API Reference#
Skeleton#
| Prop | Type | Default | 
|---|---|---|
| as | enum | div | 
| css | StitchesCss | No default value | 
| width | StitchesCss['width'] | No default value | 
| height | StitchesCss['height'] | No default value | 
| isLoaded | boolean | false | 
| animation | boolean | true | 
SkeletonText#
| Prop | Type | Default | 
|---|---|---|
| as | enum | div | 
| css | StitchesCss | No default value | 
| lines | number | 1 | 
| width | StitchesCss['width'] | No default value | 
| height | StitchesCss['height'] | No default value | 
| isLoaded | boolean | false | 
| animation | boolean | true | 
SkeletonCircle#
| Prop | Type | Default | 
|---|---|---|
| as | enum | div | 
| css | StitchesCss | No default value | 
| size | StitchesCss['width'] | No default value | 
| isLoaded | boolean | false | 
| animation | boolean | true |