Video wird geladen...

Video konnte nicht geladen werden

Zur Startseite

I recently worked on a skeleton component that works with any layout automatically. You can render any real component with mock content, wrap it with a <Skeleton>, and any text, images, etc. get replaced with a shimmer effect. Waaaay easier than manually sizing rectangles. 😃

114,650 Aufrufe • vor 1 Jahr •via X (Twitter)

9 Kommentare

Profilbild von Devon Govett
Devon Govettvor 1 Jahr

The trick is to make the text transparent, and set `box-decoration-break: clone`. Then you can animate a background gradient to create the shimmer effect, and it applies to each line fragment separately, perfectly matching the font size and layout.

Profilbild von Devon Govett
Devon Govettvor 1 Jahr

Another cool thing: you may have noticed in the video that all of the shimmer animations are synchronized, even across multiple elements. This is pretty easy to do with the Web Animations API, by setting the startTime property to zero. This took a while to figure out, but since startTime is relative to the time the user opened the page, setting it to zero makes all of the animations behave as if they had all started at simultaneously, no matter what time they actually start.

Profilbild von Mark Lenser
Mark Lenservor 1 Jahr

Anywhere we can see the code or the actual skeleton component?

Profilbild von Dr Lore
Dr Lorevor 1 Jahr

If the content is not ready and unknown how would it work? If the content is known and ready why would show a skeleton and not the content? What am I missing?

Profilbild von simey
simeyvor 1 Jahr

Pardon if I've missed something.... But a skeleton is for when there is NO CONTENT, right? So how would making content transparent be viable? Or are you proposing that all components start with lorem ipsum and then turn off the placeholder style when hydrated?

Profilbild von Devon Govett
Devon Govettvor 1 Jahr

Yeah exactly. Use fake content (but replaced with the shimmer) until the real content loads.

Profilbild von sunil pai
sunil paivor 1 Jahr

this is awesome!

Profilbild von Mark Ledwich
Mark Ledwichvor 1 Jahr

This is a really cool idea

Profilbild von Nick Cairns
Nick Cairnsvor 1 Jahr

Beautiful

Ähnliche Videos