Optimización de Web Vitals con Lighthouse
Encontrar oportunidades para mejorar la experiencia del usuario con las herramientas web de Chrome.
Hoy, cubriremos nuevas funciones de herramientas en Lighthouse, PageSpeed y DevTools para ayudar a identificar cómo tu sitio puede mejorar en Web Vitals.
Como recordatorio de las herramientas, Lighthouse es una herramienta automatizada de código abierto para mejorar la calidad de las páginas web. Puedes encontrarla en el conjunto de herramientas de depuración de Chrome DevTools y ejecutarla en cualquier página web, pública o que requiera autenticación. También puedes encontrar Lighthouse en PageSpeed Insights, CI y WebPageTest.
Lighthouse 7.x incluye nuevas funciones, como capturas de pantalla de elementos, para facilitar la inspección visual de las partes de la interfaz de usuario que afectan las métricas de la experiencia del usuario (por ejemplo, qué nodos contribuyen al cambio de diseño).
También hemos enviado soporte para capturas de pantalla de elementos en PageSpeed Insights, lo que permite detectar más fácilmente los problemas de rendimiento de las páginas en una sola ocasión.

Medir Core Web Vitals #
Lighthouse puede medir sintéticamente las métricas de Core Web Vitals, incluidas la pintura con contenido más grande, el cambio de diseño acumulativo y el tiempo de bloqueo total (un proxy de laboratorio para el retraso de la primera entrada). Estas métricas reflejan la carga, la estabilidad del diseño y la preparación para la interacción. También existen otras métricas, como la primera pintura con contenido, destacada en el futuro de Core Web Vitals (CWV).
La sección "Métricas" del informe Lighthouse incluye versiones de laboratorio de estas métricas. Puedes usar esto como una vista resumida de los aspectos de la experiencia del usuario que requieren tu atención.


Las métricas de campo, como las que se encuentran en Chrome UX Report o RUM, no tienen esta limitación y son un complemento valioso para los datos de laboratorio, ya que reflejan la experiencia que tienen los usuarios reales. Los datos de campo no pueden ofrecer el tipo de información de diagnóstico que se obtiene en el laboratorio, por lo que ambos van de la mano.
Identificar dónde se puede mejorar en Web Vitals #
Identificar el elemento de pintura con contenido más grande #
LCP (pintura con contenido más grande) es una medida de la experiencia de carga percibida. Marca el punto durante la carga de la página cuando el contenido principal o "más grande" se ha cargado y es visible para el usuario.
Lighthouse tiene una auditoría de "Elemento de pintura con contenido más grande" que identifica qué elemento fue la pintura con contenido más grande. Al pasar el cursor sobre el elemento, se resaltará en la ventana principal del navegador.

Si este elemento es una imagen, esta información es una sugerencia útil de que es posible que desees optimizar la carga de esta imagen. Lighthouse incluye una serie de auditorías de optimización de imágenes para ayudarte a comprender si tus imágenes podrían comprimirse, cambiarse de tamaño o entregarse mejor en un formato de imagen moderno más óptimo.

También puedes encontrar útil el LCP Bookmarklet de Annie Sullivan para identificar rápidamente el elemento LCP con un rectángulo rojo con solo un clic.

Precarga de imágenes descubiertas tardíamente para mejorar LCP #
Para mejorar la pintura con contenido más grande, carga previamente tus imágenes heroicas críticas si el navegador las descubre tarde. Un descubrimiento tardío puede ocurrir si un paquete de JavaScript necesita ser cargado antes de que la imagen sea descubrible.

Lighthouse 6.5 y superior sugiere ahora oportunidades para aplicar esta optimización.
Hay algunas preguntas comunes que nos hacen sobre la precarga de imágenes LCP que también puede valer la pena ver brevemente.
¿Se pueden precargar imágenes responsivas? Sí. Digamos que tenemos una imagen heroica responsiva como se especifica usando srcset
y sizes
como a continuación:
<img src="lighthouse.jpg"
srcset="lighthouse_400px.jpg 400w,
lighthouse_800px.jpg 800w,
lighthouse_1600px.jpg 1600w" sizes="50vw" alt="A helpful
Lighthouse">
Gracias a los imagesrcset
e imagesizes
agregados al link
, podemos precargar una imagen responsiva usando la misma lógica de selección de imágenes utilizada por srcset
y sizes
:
<link rel="preload" as="image" href="lighthouse.jpg"
imagesrcset="lighthouse_400px.jpg 400w,
lighthouse_800px.jpg 800w,
lighthouse_1600px.jpg 1600w"
imagesizes="50vw">
¿La auditoría también destacará las oportunidades de precarga si la imagen LCP se define mediante un fondo CSS? Si.
Cualquier imagen marcada como imagen LCP, ya sea a través de fondo CSS o <img>
es candidata si se descubre a una profundidad de cascada de tres o más.
Identificar las contribuciones de CLS (cambio de diseño acumulativo) #
El cambio de diseño acumulativo es una medida de la estabilidad visual. Cuantifica cuánto cambia visualmente el contenido de una página. Lighthouse tiene una auditoría para depurar CLS llamada "Evitar grandes cambios de diseño".
Esta auditoría destaca los elementos DOM que más contribuyen a los cambios de página. En la columna Elemento de la izquierda verás la lista de estos elementos DOM y, a la derecha, su contribución global al CLS.

Gracias a la nueva función de capturas de pantalla de elementos de Lighthouse, podemos ver una vista previa de los elementos clave anotados en la auditoría, así como hacer clic para ampliar la vista:

Para el CLS posterior a la carga, puede ser útil visualizar de forma persistente con rectángulos qué elementos contribuyeron más al CLS. Esta es una característica que encontrarás en herramientas de terceros como el panel de control Core Web Vitals de SpeedCurve y para la que me encanta usar Layout Shift GIF Generator de Defaced:

Para obtener una vista de todo el sitio de los problemas de cambio de diseño, aprovecho mucho el informe Core Web Vitals de Search Console. Esto me permite ver los tipos de páginas de mi sitio con un CLS alto (en este caso, me ayuda a identificar en qué parciales de plantilla necesito dedicar mi tiempo):

Identificación de CLS a partir de imágenes sin dimensiones #
Para limitar el cambio de diseño acumulativo causado por imágenes sin dimensiones, incluye atributos de tamaño de ancho y alto en sus imágenes y elementos de video. Este enfoque garantiza que el navegador pueda asignar la cantidad correcta de espacio en el documento mientras se carga la imagen.

Consulta Establecer la altura y el ancho en las imágenes es importante nuevamente para obtener un buen informe sobre la importancia de pensar en las dimensiones de la imagen y la relación de aspecto.
Identificación de CLS a partir de anuncios #
Publisher Ads for Lighthouse te permite encontrar oportunidades para mejorar la experiencia de carga de los anuncios en tu página, incluidas las contribuciones al cambio de diseño y las tareas largas que pueden indicar qué tan pronto los usuarios pueden utilizar tu página. En Lighthouse, puedes habilitar esto a través de Community Plugins.

Recuerda que los anuncios son una de las mayores contribuciones a los cambios de diseño en la web. Es importante:
- Tener cuidado al colocar anuncios no adhesivos cerca de la parte superior de la ventana gráfica
- Eliminar los cambios reservando el mayor tamaño posible para el espacio publicitario.
Evitar las animaciones no compuestas #
Las animaciones que no están compuestas pueden presentarse como basura en dispositivos de gama baja si las tareas pesadas de JavaScript mantienen ocupado el hilo principal. Estas animaciones pueden introducir cambios de diseño.
Si Chrome descubre que una animación no se pudo componer, la informa a una traza de DevTools que Lighthouse lee, lo que le permite enumerar qué elementos con animaciones no se compusieron y por qué motivo. Puedes encontrarlos en la auditoría Evitar animaciones no compuestas.

Depurar el retardo de la primera entrada / Tiempo total de bloqueo / Tareas largas #
La primera entrada mide el tiempo desde que un usuario interactúa por primera vez con una página (por ejemplo, cuando hace clic en un enlace, toca un botón o usa un control personalizado impulsado por JavaScript) hasta el momento en que el navegador puede empezar a procesar los controladores de eventos en respuesta a esa interacción. Las tareas largas de JavaScript pueden afectar a esta métrica y al proxy de esta métrica, el tiempo total de bloqueo.

Lighthouse incluye una auditoría Evitar las tareas largas del hilo principal que enumera las tareas más largas en el hilo principal. Esto puede ser útil para identificar los peores contribuyentes al retraso de entrada. En la columna de la izquierda podemos ver la URL de los scripts responsables de las tareas largas del hilo principal.
A la derecha podemos ver la duración de estas tareas. Como recordatorio, las tareas largas son tareas que se ejecutan durante más de 50 milisegundos. Se considera que esto bloquea el hilo principal el tiempo suficiente para afectar la velocidad de fotogramas o la latencia de entrada.
Si considero los servicios de terceros para el monitoreo, también me gusta bastante la línea de tiempo de ejecución del hilo principal visual que tiene Caliber para visualizar estos costos, que destaca tanto las tareas principales como las secundarias que contribuyen a tareas largas que impactan en la interactividad.

Bloquear solicitudes de red para ver el impacto antes / después en Lighthouse #
Chrome DevTools admite el bloqueo de solicitudes de red para ver el impacto de los recursos individuales que se eliminan o no están disponibles. Esto puede ser útil para comprender el costo que tienen los scripts individuales (por ejemplo, los rastreadores o incrustaciones de terceros) en métricas como el Tiempo de bloqueo total (TBT) y el Tiempo para interactuar.
El bloqueo de solicitudes de red también funciona con Lighthouse. Echemos un vistazo rápido al informe Lighthouse de un sitio. La puntuación de rendimiento es 63/100 con un TBT de 400 ms. Profundizando en el código, encontramos que este sitio carga un polyfill de Intersection Observer en Chrome que no es necesario. ¡Vamos a bloquearlo!

Podemos hacer clic derecho en un script en el panel de DevTools Network y hacer clic en Block Request URL
para bloquearlo. Aquí haremos esto para el polyfill Intersection Observer.

A continuación, podemos volver a ejecutar Lighthouse. Esta vez podemos ver que nuestra puntuación de rendimiento ha mejorado (70/100) al igual que el Tiempo de bloqueo total (400ms => 300ms).

Reemplazar las costosas incrustaciones de terceros con una fachada #
Es común usar recursos de terceros para incrustar videos, publicaciones en redes sociales o widgets en páginas. De forma predeterminada, la mayoría de las incrustaciones se cargan con entusiasmo de inmediato y pueden tener costosas cargas útiles que impactan negativamente en la experiencia del usuario. Esto es un desperdicio si el tercero no es crítico (por ejemplo, si el usuario necesita desplazarse antes de verlo).
Un patrón para mejorar el rendimiento de dichos widgets es cargarlos de forma diferida cuando el usuario interactúa con ellos. Esto se puede hacer renderizando una vista previa ligera del widget (una fachada) y solo se carga la versión completa si un usuario interactúa con él. Lighthouse tiene una auditoría que recomienda recursos de terceros que pueden cargarse de forma diferida con una fachada, como incrustaciones de videos de YouTube.

Como recordatorio, Lighthouse resaltará el código de terceros que bloquea el hilo principal durante más de 250 ms. Esto puede mostrar todo tipo de scripts de terceros (incluidos los creados por Google) que puede valer la pena diferir o cargar con retraso si lo que renderizan requiere desplazarse para verlo.

Más allá de Core Web Vitals #
Más allá de destacar Core Web Vitals, las versiones recientes de Lighthouse y PageSpeed Insights también intentan brindar una guía concreta que puedes seguir para mejorar la rapidez con la que se cargan las aplicaciones web con mucho JavaScript si tiene los mapas de origen activados.
Estos incluyen una creciente colección de auditorías para reducir el costo de JavaScript en tu página, como la reducción de la dependencia de polyfills y duplicados que pueden no ser necesarios para la experiencia del usuario.
Para obtener más información sobre las herramientas de Core Web Vitals, estate atento a la cuenta de Twitter del equipo de Lighthouse y a las novedades de DevTools.
Imagen heroica de Mercedes Mehling en Unsplash .