Stop the Shift! Optimizing Your Website for Cumulative Layout Shift.
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.
