LCP discovery

How the browser found the LCP resource: HTML, CSS, JS, preload, or an early-hints header.

Field data PhoneDesktopAll Scope All sites Q1 2026 edition · All devices field outcomes
Metric LCP INP CLS
1

At a glance the headline numbers for LCP discovery

How the browser found the LCP resource: HTML, CSS, JS, preload, or an early-hints header.

6
Categories
90,431 sites
68.4%
Top share
html
0.00
Top CLS
Median for html

The browser finds 68.4% of LCP images straight in the HTML. 0.8% hide behind JavaScript.

The State of Web Vitals · Q1 2026 · 94,910 sites · all devices field datacorewebvitals.io/state-of-cwv
2

LCP discovery who uses what, and how stable each group is

Median CLS
0
0.05
0.10
0.15
0.20
0.25
html0.0068% of sites
css0.0028% of sites
js0.001% of sites
header0.000% of sites
preload0.012% of sites
1030.010% of sites
VariantShare of sitesMedian
html 61,832 sites
68%
0.00
css 25,584 sites
28%
0.00
js 714 sites
1%
0.00
header 182 sites
0%
0.00
preload 2,106 sites
2%
0.01
103 13 sites
0%
0.01

Little daylight between the groups: every variant sits near 0.00 median CLS. computed

The State of Web Vitals · Q1 2026 · 94,910 sites · all devices field datacorewebvitals.io/state-of-cwv
3

Passing CLS per LCP discovery which group passes the CLS most often

VariantSitesPassing CLSCLS
103 0% 13 92% 0.01
Header 0.2% 182 92% 0.00
Html 68.4% 61,832 88% 0.00
Css 28.3% 25,584 87% 0.00
Preload 2.3% 2,106 87% 0.01
Js 0.8% 714 86% 0.00
Good Needs Improvement Poor Sorted best-passing first · median colored by its own rating · pass = good CLS (0.1 at p75) · one value per site

92% of Header sites pass CLS. Js trails 6 points behind. computed

The State of Web Vitals · Q1 2026 · 94,910 sites · all devices field datacorewebvitals.io/state-of-cwv
4

Why this matters for the Core Web Vitals, and where to start fixing it

The browser can only download what it has discovered, and the LCP's load delay is mostly discovery time. An image in the HTML markup is found by the preload scanner in the first bytes of the document. A CSS background image stays invisible until the stylesheet downloads and applies. An image injected by JavaScript stays invisible until that script downloads, parses and runs.

That order is the fix list. Get the LCP image into the markup, or preload it when it cannot be. Discovery through JavaScript is the slowest possible path for the most important pixels on the page.

How does this affect the Core Web Vitals?

LCP discovery correlates with the LCP. With HTML, 85% of sites pass the LCP. With JS, 70% do.

Related signals LCP image size → LCP element type → LCP origin → LCP image format → Chrome field data from 94,910 sites, representing millions of real page loads · How we measured