什么是lcp,lcp优化问题

网站搭建 z197 1294次浏览 已收录 用手机观看

LCP,即Largest Contentful Paint 最大内容绘制

什么是 LCP

最大内容绘制 (LCP) 指标会根据页面首次开始加载的时间点来报告可视区域内可见的最大图像或文本块完成渲染的相对时间。

最大内容绘制 (LCP) 是测量感知加载速度的一个以用户为中心的重要指标,因为该项指标会在页面的主要内容基本加载完成时,在页面加载时间轴中标记出相应的点,迅捷的 LCP 有助于让用户确信页面是有效的。

长久以来,对于网页开发者来说,测量网页主要内容的加载速度和内容对用户的显示速度一直是一个挑战。

诸如load(加载)或DOMContentLoaded(DOM 内容加载完毕)这样的旧有指标并不是很好,因为这些指标不一定与用户在屏幕上看到的内容相对应。而像First Contentful Paint 首次内容绘制 (FCP)这类以用户为中心的较新性能指标只会捕获加载体验最开始的部分。如果某个页面显示的是一段启动画面或加载指示,那么这些时刻与用户的关联性并不大。

我们以往推荐过一些性能指标,例如First Meaningful Paint 首次有效绘制 (FMP)和Speed Index 速度指数 (SI) (两个指标都包含在灯塔工具中),这些指标有助于捕获到更多初始绘制后的加载体验,但这些指标十分复杂、难以解释,而且常常出错,也就意味着这些指标仍然无法识别出页面主要内容加载完毕的时间点。

有时候简胜于繁。根据W3C Web 性能工作组的讨论以及 Google 进行的研究,我们发现更准确地测量页面主要内容加载完毕的时间点的方法是查看最大元素完成渲染的时间点。

怎样算是良好的 LCP 分数

为了提供良好的用户体验,网站应该努力将最大内容绘制控制在2.5 秒或以内。为了确保您能够在大部分用户的访问期间达成建议目标值,一个良好的测量阈值为页面加载的第 75 个百分位数,且该阈值同时适用于移动和桌面设备。

哪些元素在考量范围内

根据当前最大内容绘制 API中的规定,最大内容绘制考量的元素类型为:

<img>元素
内嵌在<svg>元素内的<image>元素
<video>元素(使用封面图像)
通过url()函数(而非使用CSS 渐变)加载的带有背景图像的元素
包含文本节点或其他行内级文本元素子元素的块级元素。
请注意,为了在初始阶段保持简洁,我们有意将元素限制在这几个有限的类型中。随着研究的深入,未来可能会添加其他元素(例如<svg> 、 <video>)。

如何确定一个元素的大小

报告给最大内容绘制的元素大小通常是用户在可视区域内可见的大小。如果有元素延伸到可视区域之外,或者任何元素被剪裁或包含不可见的溢出,则这些部分不计入元素大小。

对于在原始尺寸之上经过调整的图像元素,报告给指标的元素大小为可见尺寸或原始尺寸,以尺寸较小者为准。例如,远小于其原始尺寸的缩小图像将仅报告图像的显示尺寸,而拉伸或放大成更大尺寸的图像将仅报告图像的原始尺寸。

对于文本元素,指标仅考量其文本节点的大小(包含所有文本节点的最小矩形)。

对于所有元素,通过 CSS 设置的任何边距、填充或边框都不在考量范围内。

确定哪些文本节点属于哪些元素有时会很棘手,尤其是对于子元素既包括行内元素和纯文本节点,又包括块级元素的一部分元素。关键点在于每个文本节点都属于(且仅属于)其最近的块级祖先元素。用规范术语来解释:每个文本节点都属于生成其包含块的对应元素。

何时报告最大内容绘制

网页通常是分阶段加载的,因此,页面上的最大元素也可能会发生变化。

为了应对这种潜在的变化,浏览器会在绘制第一帧后立即分发一个largest-contentful-paint类型的PerformanceEntry,用于识别最大内容元素。但是,在渲染后续帧之后,浏览器会在最大内容元素发生变化时分发另一个PerformanceEntry。

例如,在一个带有文本和首图的网页上,浏览器最初可能只渲染文本部分,并在此期间分发一个largest-contentful-paint条目,其element属性通常会引用一个<p>或<h1> 。随后,一旦首图完成加载,浏览器就会分发第二个largest-contentful-paint条目,其element属性将引用<img> 。

需要注意的是,一个元素只有在渲染完成并且对用户可见后才能被视为最大内容元素。尚未加载的图像不会被视为"渲染完成"。 在字体阻塞期使用网页字体的文本节点亦是如此。在这种情况下,较小的元素可能会被报告为最大内容元素,但一旦更大的元素完成渲染,就会通过另一个PerformanceEntry对象进行报告。

除了延迟加载图像和字体之外,页面可能会在新内容可用时向 DOM 添加新元素。如果有任意一个新元素大于先前的最大内容元素,则浏览器还将报告一个新的PerformanceEntry。

如果当前的最大内容元素从可视区域被移除(甚至从 DOM 中被移除),那么除非有一个更大的元素完成渲染,否则该元素将持续作为最大内容元素。

在 Chrome 88 之前,已移除的元素不会被视为最大内容元素,而移除当前候选对象时会触发浏览器分发一个新的largest-contentful-paint条目。但是,该项指标已经针对流行的用户界面模式(例如经常将 DOM 元素移除的图像轮播)进行了更新,进而更准确地反映用户体验。请参阅更新日志 ,了解更多详情。
当用户与页面进行交互(通过轻触、滚动或按键)时,浏览器将立刻停止报告新条目,因为用户交互通常会改变用户可见的内容(滚动操作时尤其如此)。

出于分析目的,您应该仅向您的分析服务报告最近一次分发的PerformanceEntry。

由于用户可以在后台选项卡中打开页面,而用户聚焦该选项卡的时间点可能远远晚于第一次加载页面的时间点,因此在用户聚焦该选项卡之前可能不会进行最大内容绘制。

加载时间 vs. 渲染时间

出于安全考虑,对于缺少Timing-Allow-Origin标头的跨域图像来说,图像的渲染时间戳不会得到公开。相反,只有图像的加载时间会得到公开(因为加载时间已经通过其他许多网页 API 得到了公开)。

下方的使用示例说明了如何处理渲染时间不可用的元素。但是,我们始终建议您在可能的情况下设置好Timing-Allow-Origin标头,从而使您的指标更加准确。

如何处理元素布局和元素大小更改? #
为了使计算和分发新性能条目的性能开销保持较低的水平,对元素大小或位置的更改不会生成新的 LCP 候选对象。只有元素在可视区域内的初始大小和位置会被纳入考量范围。

也就是说,最初在屏幕外完成渲染,然后过渡到屏幕上的图像可能不会得到报告。这也意味着最初在可视区域内进行渲染,然后被推出可视区域外的元素仍将报告其在可视区域内的初始大小。

如何改进 LCP

LCP 主要受四个因素影响:

缓慢的服务器响应速度
JavaScript 和 CSS 渲染阻塞
资源加载时间
客户端渲染