Skeleton
Skeleton
Introduction
Skeleton has three variants:
-
Circle
-
Text
-
Rectangle
Interactive example
Circle
Use the circle variant as a placeholder for any circular components, like avatars and circular logos.
Text
Use the text variant as a placeholder for any text or labels that sit outside of any component. This applies to helper text for input labels, headings and body text.
Rectangle
Use the rectangle variant as a placeholder for any other components. This includes buttons, chips and tags, input fields and cards.
When to use
Use skeleton variants as a placeholder for when a full page or individual components are loading. Don't nest skeletons. If a label or text is wrapped inside a component, for example in cards, only use the skeleton variant of the component that wraps the other components.
data:image/s3,"s3://crabby-images/6c27e/6c27e55539b0b49f6c5e8ee8407898fc51b3a4d3" alt="An image which shows the card component and the rectangle skeleton variant used to replace the full card width and height while it’s loading."
data:image/s3,"s3://crabby-images/a8b05/a8b0584ee8e14204ce0d1550dc9c19eea09a78b2" alt="An image showing a card component’s skeleton state including text skeleton variants used within another rectangle skeleton variant."
Sizing
Set the height and width of the skeleton to match the size of the component that will replace it once loaded.
When using the text variant, set the skeleton’s height to match the text style of the text that will replace it once loaded.
data:image/s3,"s3://crabby-images/310fe/310fe80887b614993c6654837b51c9f29a05e2b5" alt="A graphic of a list of text styles side by side with the correct text variant height."
data:image/s3,"s3://crabby-images/a6452/a64529f13e193db0f04992499b66118c5d3d6094" alt="A graphic of a list of different text styles side by side with a list of skeleton components of the same height."
Don't replace large bodies of texts with one single large text skeleton. Replace each line with a separate text skeleton.
data:image/s3,"s3://crabby-images/aeb22/aeb22a1f22f4157059030d4f243e143630952b26" alt="An image showing multiple lines of text being replaced by multiple text skeleton components for each line of text."
data:image/s3,"s3://crabby-images/f141f/f141fa51748b7119d038369b8b2d42549fea93ff" alt="An image showing multiple lines of text being incorrectly replaced by one large custom text skeleton."
When not to use
Avoid displaying skeleton placeholders when something will load in 300ms or under to avoid flashing on the page. If needed, manually specify a 300ms delay, after which the skeleton component is displayed.
Don’t use skeleton loading states when the loading progress can be calculated. Instead, use
Don’t use skeleton components when the general structure of the page that will replace skeleton variants is not known. Instead, use