GoogleChrome / lighthouse

Automated auditing, performance metrics, and best practices for the web.
https://developer.chrome.com/docs/lighthouse/overview/
Apache License 2.0
28.21k stars 9.34k forks source link

NO_LCP on Mobile but there is one on Desktop #16157

Open JamesSingleton opened 3 weeks ago

JamesSingleton commented 3 weeks ago

FAQ

URL

https://www.redshirtsports.xyz/western-carolina-looks-for-breakthrough-season

What happened?

I updated my website to use next-sanity/image component so that I could use next/image with a custom loader and pushed it to production. The image loads fine, however, running the tests in PageSpeed Insights and in lighthouse show

Screenshot 2024-08-19 at 10 41 45 PM

https://pagespeed.web.dev/analysis/https-www-redshirtsports-xyz-western-carolina-looks-for-breakthrough-season/rpwlle03o1?form_factor=mobile

What did you expect?

That there would be an LCP for mobile due to the fact that there is one for desktop

What have you tried?

No response

How were you running Lighthouse?

PageSpeed Insights, Chrome DevTools

Lighthouse Version

12.0.0

Chrome Version

127.0.6533.120

Node Version

No response

OS

Mac

Relevant log output

No response

adamraine commented 3 weeks ago

This looks like a bug in Chrome because I can reproduce this with the performance panel.

I noticed the image (which should be the LCP) loads in a blurry version before replacing it with the full resolution image. It seems likely that Chrome is getting tripped up on this. Is this progressive loading a part of your custom loader?

JamesSingleton commented 3 weeks ago

This looks like a bug in Chrome because I can reproduce this with the performance panel.

I noticed the image (which should be the LCP) loads in a blurry version before replacing it with the full resolution image. It seems likely that Chrome is getting tripped up on this. Is this progressive loading a part of your custom loader?

I guess so, I am using https://github.com/sanity-io/next-sanity/blob/main/packages/next-sanity/src/image/Image.tsx which uses next/image under the hood. And then I am using it like so

<SanityImage
  src={urlForImage(post.mainImage).width(865).height(575).url()}
  className="h-auto w-full rounded-lg shadow-md"
  width={865}
  height={575}
  sizes="100vw"
  alt={post.mainImage.asset.altText ?? post.mainImage.caption}
  placeholder="blur"
  blurDataURL={
    post.mainImage.asset.metadata?.lqip ??
    urlForImage(post.mainImage).width(24).height(24).blur(10).url()
  }
  priority
/>

So I am telling it to use a blur placeholder and then IF the image metadata includes lqip to use that or else use a tiny image.

adamraine commented 3 weeks ago

Thanks @JamesSingleton any chance you could create a minimum repro of this? If my prediction is correct we can probably reproduce this with the image component on a blank page. I can use that to file a bug report in Chrome.

JamesSingleton commented 3 weeks ago

I can try. Just for fun, I tried removing the placeholder="blur" and I actually now have an LCP on mobile.

Screenshot 2024-08-20 at 3 26 15 PM

Adding the placeholder="blur" along with the blurDataURL causes it to happen again.

Screenshot 2024-08-20 at 3 28 40 PM

For this image, the lqip ends up being



I am also guessing I probably shouldn't have a blur placeholder for an above fold image though 🤔