Stop the Shift! Optimizing Your Website for Cumulative Layout Shift.

Chris:

Okay. So today, we are gonna be talking about, making sure that websites, you know, don't do that thing that everybody hates.

Alice:

Okay.

Chris:

Which is, like, when you're trying to click on something and then it moves. Good. Because something above it loaded. Yeah. Yeah.

Chris:

Like, we're talking about page jumps.

Alice:

Yeah. Those annoying page jumps that happen while a web page is loading.

Chris:

Right. And we all hate it.

Alice:

Yeah. Absolutely.

Chris:

And, you know, I think most people probably don't realize Right. That it's, like, actually a pretty serious business problem. It is. It's not just like a pet peeve.

Alice:

Yeah. It can make or break your website's success

Chris:

Right.

Alice:

Because if people are getting frustrated trying to use your website, they're gonna leave, and they are gonna go somewhere else.

Chris:

Right. And they might not come

Alice:

back. Exactly.

Chris:

So this is something that has a name.

Alice:

It does.

Chris:

It's called CLS.

Alice:

CLS, cumulative layout shift.

Chris:

Right.

Alice:

So that experience of elements shifting unexpectedly as a page loads, that's CLS. CLS. Okay.

Chris:

So CLS and we have some really interesting research on this. Yeah. There's a really good case study from a Polish

Alice:

Okay.

Chris:

Ecommerce agency Okay. Called bcommerce.pl.

Alice:

I've heard of them. Yeah. They're great.

Chris:

They're really good.

Alice:

Yeah.

Chris:

And they work with this fashion website called egardarobe.com.

Alice:

Okay.

Chris:

And they had some really good insights, I think, that we can all learn from.

Alice:

Yeah. Bcommerce.pl really knows their stuff and what they emphasize. And I think this is crucial, especially for anybody out there who runs an ecommerce website. High CLS directly impacts your bottom line.

Chris:

So more page jumps equals

Alice:

Less money.

Chris:

Less money.

Alice:

Okay.

Chris:

Yeah. Yeah. So how does that actually work?

Alice:

Well, so think about this. You're browsing. Let's say you're on egarterobe.com. You see a dress you like.

Chris:

Okay.

Alice:

And you're about to hit add to cart. Mhmm. But at that exact moment, the image above the button finishes loading

Chris:

Always.

Alice:

Pushes the button down

Chris:

Right.

Alice:

And you end up clicking on the wrong size

Chris:

Oh. Yeah.

Alice:

Or the wrong color or Or

Chris:

the wrong item either.

Alice:

Or the wrong item either. Yeah. And that is so frustrating as a customer, and you know what happens? You get frustrated, and you abandon your cart.

Chris:

Right.

Alice:

And this is something that Google has picked up on, and this is why Google actually uses CLS as a ranking factor.

Chris:

What does that mean?

Alice:

It means that Google is looking at how much your content is jumping around.

Chris:

Okay.

Alice:

Because Google wants to promote websites that offer a smooth and enjoyable experience for users.

Chris:

Right. It makes sense because, like Yeah. A jumpy website just feels

Alice:

Chanky. Yeah. Chank. Untrustworthy, unprofessional.

Chris:

Right. It just it feels like

Alice:

Sketchy. Sketchy.

Chris:

Yeah. Like, I don't know. I wanna give you my credit card information.

Alice:

Exactly. What are you hiding?

Chris:

Right. Exactly what you gotta okay. So Google is using this as a ranking factor.

Alice:

They are.

Chris:

Which means that this is something that we should all be paying attention to. 100%. So what does Google actually like to see what's a good CLS score?

Alice:

So Google likes to see a CLS score of point 1 or less.

Chris:

Point 1 or less?

Alice:

Or less. Yeah. Anything above 0.25 is considered poor.

Chris:

Oh, wow. Okay.

Alice:

And a lot of websites struggle with this, especially websites that have a lot of images or a lot of dynamic content.

Chris:

So let's go back to edashgarterobe.com.

Alice:

Okay.

Chris:

Because that's a website that obviously has a lot of images.

Alice:

Tons of images.

Chris:

Because it's a fashion website. Right. So what did bcommerce.pl

Alice:

do Okay.

Chris:

To tackle this issue on that site?

Alice:

So one of the things that they use, one of the key things they use is what I have the padding top hack Okay. Which sounds very technical It does. But it's actually quite simple Okay. And elegant in its simplicity.

Chris:

I'm intrigued. Break it down for

Alice:

us. Okay. So, basically, when a browser loads a web page

Chris:

Okay.

Alice:

It needs to know how much space to reserve for an image before it fully loads.

Chris:

Right.

Alice:

If you don't tell the browser how big the image is gonna be Uh-huh. Then the content below the image has to just kind of, like, guess. Right. And so it ends up moving around, shifting around as the image downloads. Right.

Alice:

And that's where

Chris:

you get that jump. Right. And I can just imagine on a website like egardorobe.com, where they probably have these big beautiful product photos Yeah. That it would be

Alice:

A nightmare.

Chris:

A nightmare.

Alice:

If they didn't do this.

Chris:

If they didn't figure out a way around this.

Alice:

Yeah.

Chris:

So the padding top hack?

Alice:

Yes. So the padding top hack, what this does is it essentially uses a little bit of code. It's called CSS.

Chris:

Okay.

Alice:

And it says to the browser, hey. Reserve this much space for the image even if you haven't downloaded it yet.

Chris:

Oh, that's so smart.

Alice:

Yeah.

Chris:

So it's like you're hold holding the spot.

Alice:

Exactly.

Chris:

For the image. Yeah.

Alice:

It's like reserving a parking spot for the image.

Chris:

And then everything else on the page can just kinda, like

Alice:

Stays put.

Chris:

Stay put and load. Yeah.

Alice:

And it creates the smooth, almost instantaneous loading experience

Chris:

That's awesome.

Alice:

Which is what users expect these days.

Chris:

Right. Because nobody wants to wait around Nobody. For your website to load.

Alice:

Especially on mobile.

Chris:

Why especially on mobile?

Alice:

Every millisecond counts

Chris:

I like that. When it

Alice:

comes to user experience.

Chris:

Every millisecond counts.

Alice:

Write that down.

Chris:

That's going on a T shirt.

Alice:

I love it.

Chris:

Okay.

Alice:

Alright.

Chris:

So we've talked about images, but what about other things that can cause CLS issues? Because I'm thinking

Alice:

Oh, yeah. There's more.

Chris:

Images aren't the only culprit.

Alice:

No. They are not the only culprit. Ads

Chris:

Oh, yeah.

Alice:

Embedded videos

Chris:

Oh, right.

Alice:

Custom fonts.

Chris:

Interesting.

Alice:

All of these things

Chris:

Alright.

Alice:

If they're not loaded properly, can contribute to a jumpy layout.

Chris:

Right. It's amazing how much goes on behind the scenes

Alice:

Yeah.

Chris:

Of a seemingly simple web page.

Alice:

Oh, yeah. People don't realize.

Chris:

The complexity.

Alice:

Yeah. Like, even things like those websites where it's like, as you scroll down, more stuff loads.

Chris:

Oh, yeah.

Alice:

What is that even called?

Chris:

That's called dynamic content.

Alice:

Dynamic content. Okay. And I feel like that must be

Chris:

A CLS nightmare.

Alice:

Yes.

Chris:

It can be if you're not careful.

Alice:

So how do you prevent that? Like, what do you do?

Chris:

So there are a few techniques

Alice:

Okay.

Chris:

You can use to mitigate CLS issues with dynamic content. Right? Because it seems like a trade off.

Alice:

Yeah.

Chris:

Because you want your site to feel fast and interactive and you want all that new content to load, but you also don't want it to be at the expense

Alice:

of Of stability.

Chris:

Yeah.

Alice:

Visual stability.

Chris:

Right.

Alice:

You're right. It is a balancing act.

Chris:

Yeah.

Alice:

But one really effective method that you can use is to use what are called placeholders.

Chris:

Placeholders. Okay. Yeah. So you're, like, holding

Alice:

Yeah. You're, like, reserving the space

Chris:

Okay.

Alice:

For the content before it loads.

Chris:

Got it.

Alice:

So it's like, if you were to leave space in a bookshelf

Chris:

Okay. For

Alice:

a new book that you're gonna get

Chris:

I like that.

Alice:

You know you know something's gonna go there. So you keep that space open, and then you don't have to, like, rearrange all the books later.

Chris:

That's a great analogy. Right. Okay. So placeholders got it. What about Yeah.

Chris:

You mentioned custom fonts earlier. Yeah. How do those cause layout shifts? Because that one, I don't really understand.

Alice:

Yeah. So you know how sometimes you'll load a web page and you'll see the text, and it looks kinda like

Chris:

That looks weird.

Alice:

It looks weird for a second, and then suddenly it changes.

Chris:

Yes.

Alice:

You know what I'm talking about.

Chris:

And it's always super distracting.

Alice:

It is.

Chris:

It's like, what is going on here?

Alice:

It's like blinking.

Chris:

Yeah.

Alice:

Yeah. And that's called a flash of unstyled text or f o t.

Chris:

Oh my gosh. F o u t. Yeah. I'm adding that to the t shirt list.

Alice:

So that happens because the browser is using a default font

Chris:

Okay.

Alice:

While it downloads the website's custom font. Right. And if those custom fonts have different dimensions than the default font, then you get this, like

Chris:

The jump.

Alice:

The jump.

Chris:

Yeah.

Alice:

Yeah. So, like, all the text has to, like, readjust

Chris:

Right. Yeah.

Alice:

Once the custom font is loaded.

Chris:

And, obviously, you don't want that to happen because No.

Alice:

You don't want that.

Chris:

Especially for, like, a brand.

Alice:

Yeah. Especially for a brand that's, like, really into it.

Chris:

Like egarterrobe.com was all about, like, having this certain

Alice:

Visual identity. Look. Yeah. If you go to, like, a high end fashion website Right. And the the text is like

Chris:

Jump it all over.

Alice:

Yeah. Just like Not

Chris:

very high end.

Alice:

Yeah. Not a good look.

Chris:

Not a good look. No. Okay. So how do we fix FOT?

Alice:

So one way to fix FOT is to use a font loading strategy called font display swap Okay. Which basically just tells the browser to use a fallback font

Chris:

Okay.

Alice:

That is visually similar to the custom font

Chris:

Got it.

Alice:

Until the custom font is fully loaded.

Chris:

Okay.

Alice:

That way, even if there is, like, a slight delay

Chris:

Yeah.

Alice:

The text doesn't jump around

Chris:

Right.

Alice:

Dramatically.

Chris:

Okay.

Alice:

And the user experience remains smooth.

Chris:

So it's, like, kinda like the padding thing

Alice:

Yeah. Exactly.

Chris:

But for fonts. Exactly. Wow. This is

Alice:

It's a lot.

Chris:

There's a lot to think about here Yeah. When you're trying to create, like, a good web experience.

Alice:

Yeah. It's like a real art form.

Chris:

Yeah. And it seems like it's very technical.

Alice:

It can be.

Chris:

Like, all this stuff with the code and everything?

Alice:

It can be. Yeah. But, luckily, there are tools and frameworks available these days

Chris:

Okay. Good.

Alice:

That can help you implement these best practices without having to be, like, a coding whiz.

Chris:

Okay.

Alice:

You know?

Chris:

That's good because I'm not a coding whiz.

Alice:

Yeah. Most people aren't. Yeah. And that's okay.

Chris:

And this is especially true when we start talking about PWAs.

Alice:

Oh, yeah. PWAs. Okay. Now tell me more about those because I've heard of those, but I don't really know

Chris:

Yeah.

Alice:

What they are.

Chris:

Okay. So PWAs or progressive web apps.

Alice:

Okay.

Chris:

They're basically websites that look and feel like native apps.

Alice:

Oh, okay. So they're like those?

Chris:

Yeah. They're like those app like websites

Alice:

Okay.

Chris:

That everybody's talking about these days, and they're all about speed Okay. And responsiveness.

Alice:

Got

Chris:

it. So minimizing CLS is really, really important for PWAs.

Alice:

Okay. Because they're already trying to be so fast. Exactly. And so if you've got CLS issues on top of that Yeah.

Chris:

It's gonna be even more noticeable.

Alice:

That's not gonna be good.

Chris:

Yeah. Not a good look.

Alice:

Not a good look.

Chris:

Okay.

Alice:

So what's interesting about PWAs, though, is that they often utilize a technique called server side rendering

Chris:

Look at that.

Alice:

Which can significantly help minimize CLS.

Chris:

Okay.

Alice:

So imagine walking into a restaurant

Chris:

Okay.

Alice:

Where the table is already set. The food is prepared.

Chris:

I like where this is going.

Alice:

And the waiter is ready to take your order.

Chris:

Okay.

Alice:

That's server side rendering.

Chris:

You had me at food is prepared.

Alice:

It's like getting the user a fast and seamless experience right from the moment they arrive.

Chris:

Okay. I got it. That sounds delightful. But in the context of a website, what does that actually mean?

Alice:

It means that instead of the browser having to fetch all of the different elements of a web page individually, like the HTML, the CSS, the JavaScript, the images, all that stuff. With server side rendering, it gets a more complete package right from the start.

Chris:

So it's like getting a preassembled piece of furniture instead of a box of parts that you have to put together yourself.

Alice:

Exactly. And just like with that preassembled furniture, the initial setup is much faster and less prone to, well, unexpected shifts.

Chris:

So in the context of PWAs, that means less waiting around for images to load, fonts to render, and all those things that contribute to CLS.

Alice:

Exactly. Server side rendering gives PWAs a head start in the race against layout shifts, resulting in that smoother, more app like experience that users love.

Chris:

So for anyone listening who's thinking about building a PWA, it sounds like server side rendering is a must have for a smooth and engaging user experience.

Alice:

Absolutely. It's a win win. It makes the site feel faster for users, and it helps boost your ranking in Google's eyes.

Chris:

This whole deep dive has been really eye opening. It's amazing how these seemingly small technical details can make or break website success.

Alice:

It's all about respecting your users' time and attention, especially in today's fast paced digital world. Every time a user encounters friction, even something as subtle as a layout shift, it ships away at their engagement and trust.

Chris:

That's so true. Well, as we wrap up, is there one key takeaway you wanna leave our listeners with regarding CLS and its importance?

Alice:

I'd say this. In today's world, users expect instant gratification. A website that loads quickly and remains visually stable throughout demonstrates care for the user's time. Prioritizing a low CLS is about more than just technical SEO. It's about building a brand that respects its users, and that's a recipe for success in any era.

Chris:

Beautifully said. Thank you so much for sharing your expertise with us today. It's been a pleasure diving deep into the world of CLS.

Alice:

It was my pleasure.

Chris:

And to our listeners, we hope you found this as insightful as we did. Until next time. Happy browsing.

Stop the Shift! Optimizing Your Website for Cumulative Layout Shift.
Broadcast by