Back to Element Plus

Skeleton

docs/en-US/component/skeleton.md

2.13.76.8 KB
Original Source

Skeleton

When loading data, and you need a rich experience for visual and interactions for your end users, you can choose skeleton.

Basic usage

The basic skeleton.

:::demo

skeleton/basic-usage

:::

Configurable Rows

You can configure the row numbers yourself, for more precise rendering effect, the actual rendered row number will always be 1 row more than the given number, that is because we are rendering a title row with 33% width of the others.

:::demo

skeleton/configurable-rows

:::

Animation

We have provided a switch flag indicating whether showing the loading animation, called animated when this is true, all children of el-skeleton will show animation

:::demo

skeleton/animation

:::

Customized Template

Element Plus only provides the most common template, sometimes that could be a problem, so you have a slot named template to do that work.

Also we have provided different types skeleton unit that you can choose, for more detailed info, please scroll down to the bottom of this page to see the API description. Also, when building your own customized skeleton structure, you should be structuring them as closer to the real DOM as possible, which avoiding the DOM bouncing caused by the height difference.

:::demo

skeleton/customized-template

:::

Loading state

When Loading ends, we always need to show the real UI with data to our end users. with the attribute loading we can control whether showing the DOM. You can also use slot default to structure the real DOM element.

:::demo

skeleton/loading-state

:::

Rendering a list of data

Most of the time, skeleton is used as indicators of rendering a list of data which haven't been fetched from server yet, then we need to create a list of skeleton out of no where to make it look like it is loading, with count attribute, you can control how many these templates you need to render to the browser.

:::tip

We do not recommend rendering lots of fake UI to the browser, it will still cause the performance issue, it also costs longer to destroy the skeleton. Keep count as small as it can be to make better user experience.

:::

:::demo

skeleton/rendering-with-data

:::

Avoiding rendering bouncing.

Sometimes API responds very quickly, when that happens, the skeleton just gets rendered to the DOM then it needs to switch back to real DOM, that causes the sudden flashy. To avoid such thing, you can use the throttle attribute.

:::tip

Since ^(2.8.8), the throttle attribute supports two values: number and object. When passing a number, it is equivalent to {leading: xxx}, controlling the throttling of the skeleton screen display. Of course, you can also control the throttling of the skeleton screen disappearance by passing {trailing: xxx}

:::

:::demo

skeleton/avoiding-rendering-bouncing

:::

Initial rendering loading ^(2.8.8)

When the initial value of loading is true, you can set throttle: {initVal: true, leading: xxx} to control the immediate display of the initial skeleton screen without throttling.

:::demo

skeleton/initial-rendering-loading

:::

Toggle show/hide without rending bouncing ^(2.8.8)

:::tip

You can set throttle: {initVal: true, leading: xxx, trailing: xxx} to control the initial display of the skeleton effect and to make the transition of the skeleton more smooth when switching loading states.

:::

Sometimes you want to render the business components more smoothly when loading toggle show or hide. You can use set the throttle: {leading: xxx, trailing:xxx} to control the rendering bouncing.

:::demo

skeleton/leading-trailing-without-bouncing

:::

Skeleton API

Skeleton Attributes

NameDescriptionTypeDefault
animatedwhether showing the animation^[boolean]false
counthow many fake items to render to the DOM^[number]1
loadingwhether showing the real DOM^[boolean]false
rowsnumbers of the row, only useful when no template slot were given^[number]3
throttlerendering delay in milliseconds. Numbers represent delayed display, and can also be set to delay hide, for example { leading: 500, trailing: 500 }. When needing to control the initial value of loading, you can set { initVal: true }^[number] / ^[object]{ leading?: number, trailing?: number, initVal?: boolean }0

Skeleton Slots

NameDescriptionType
defaultreal rendering DOM^[object]$attrs
templatecontent as rendering skeleton template^[object]{ key: number }

SkeletonItem API

SkeletonItem Attributes

NameDescriptionTypeDefault
variantthe current rendering skeleton type^[enum]'p' | 'text' | 'h1' | 'h3' | 'caption' | 'button' | 'image' | 'circle' | 'rect'text