Descripción
This plugin’s purpose is to optimize the performance of embeds in WordPress, such as Tweets, YouTube videos, TikToks, and others.
The current optimizations include:
- Lazy loading embeds just before they come into view.
- Adding preconnect links for embeds in the initial viewport.
- Reserving space for embeds that resize to reduce layout shifting.
Lazy loading embeds improves performance because embeds are generally very resource-intensive, so lazy loading them ensures that they don’t compete with resources when the page is loading. Lazy loading of IFRAME
-based embeds is handled simply by adding the loading=lazy
attribute. Lazy loading embeds that include SCRIPT
tags is handled by using an Intersection Observer to watch for when the embed’s FIGURE
container is going to enter the viewport, and then it dynamically inserts the SCRIPT
tag.
This plugin also recommends that you install and activate the Optimization Detective plugin, which unlocks several optimizations beyond just lazy loading. Without Optimization Detective, lazy loading can actually degrade performance when an embed is positioned in the initial viewport. This is because lazy loading such viewport-initial elements can degrade LCP since rendering is delayed by the logic to determine whether the element is visible. This is why WordPress Core tries its best to avoid lazy loading IMG
tags which appear in the initial viewport, although the server-side heuristics aren’t perfect. This is where Optimization Detective comes in since it detects whether an embed appears in any breakpoint-specific viewports, like mobile, tablet, and desktop. (See also the Image Prioritizer plugin which extends Optimization Detective to ensure lazy loading is correctly applied based on whether an IMG is in the initial viewport.)
When Optimization Detective is active, it will start keeping track of which embeds appear in the initial viewport based on actual visits to your site. With this information in hand, Embed Optimizer will then avoid lazy loading embeds which appear in the initial viewport. Furthermore, for such above-the-fold embeds Embed Optimizer will also add preconnect links for resources known to be used by those embeds. For example, if a YouTube embed appears in the initial viewport, Embed Optimizer with Optimization Detective will omit loading=lazy
while also adding a preconnect link for https://i.ytimg.com
which is the domain from which YouTube video poster images are served. Such preconnect links cause the initial-viewport embeds to load even faster.
The other major feature in Embed Optimizer enabled by Optimization Detective is the reduction of layout shifts caused by embeds that resize when they load. This is seen commonly in WordPress post embeds or Tweet embeds. Embed Optimizer keeps track of the resized heights of these embeds. With these resized heights stored, Embed Optimizer sets the appropriate height on the container FIGURE element as the viewport-specific min-height
so that when the embed loads it does not cause a layout shift.
Since Optimization Detective relies on page visits to learn how the page is laid out, you’ll need to wait until you have visits from a mobile and desktop device to start seeing optimizations applied. Also, note that Optimization Detective does not apply optimizations by default for logged-in admin users.
Please note that the optimizations are intended to apply to Embed blocks. So if you do not see optimizations applied, make sure that your embeds are not inside a Classic Block.
Your site must have the REST API accessible to unauthenticated frontend visitors since this is how metrics are collected about how a page should be optimized. There are currently no settings and no user interface for this plugin since it is designed to work without any configuration.
Instalación
Instalación desde WordPress
- Visita Plugins > Añadir nuevo.
- Busca Embed Optimizer.
- Instala y activa el plugin Embed Optimizer.
Instalación manual
- Sube toda la carpeta
embed-optimizer
al directorio/wp-content/plugins/
. - Visita Plugins.
- Activa el plugin Embed Optimizer.
FAQ
-
¿Dónde puedo enviar mis comentarios sobre el plugin?
-
Se anima y se agradecen los comentarios, especialmente dado que este plugin podría incluir características del núcleo de WordPress en el futuro. Si tienes sugerencias o peticiones de nuevas características, puedes enviarlas como un problema en el repositorio de GitHub del Equipo de Rendimiento de WordPress. Si necesitas ayuda para diagnosticar o tienes una pregunta sobre el plugin, por favor crea un nuevo debate en nuestro foro de soporte
-
¿Dónde puedo informar fallos de seguridad?
-
El equipo de rendimiento y la comunidad WordPress se toman en serio los fallos de seguridad. Apreciamos tu esfuerzo para divulgar responsablemente tus hallazgos, y haremos todo lo posible para reconocer tus contribuciones.
Para informar de un problema de seguridad, visita el programa WordPress HackerOne.
-
¿Cómo puedo contribuir al plugin?
-
¡Las contribuciones son siempre bienvenidas! Obtén más información sobre cómo participar en el manual del equipo de rendimiento.
El código fuente del plugin se encuentra en el repo de WordPress/performance en GitHub.
Reseñas
No hay valoraciones para este plugin.
Colaboradores y desarrolladores
«Embed Optimizer» es un software de código abierto. Las siguientes personas han colaborado con este plugin.
Colaboradores«Embed Optimizer» está traducido en 7 idiomas. Gracias a los traductores por sus contribuciones.
Traduce «Embed Optimizer» a tu idioma.
¿Interesado en el desarrollo?
Revisa el código , echa un vistazo al repositorio SVN o suscríbete al registro de desarrollo por RSS.
Registro de cambios
1.0.0-beta2
Mejoras
- Update
OD_HTML_Tag_Processor::next_tag()
to allow$query
arg and prepare to skip visiting tag closers by default. (1872) - Expose the logging functions to client-side extensions and automatically account for the value of
isDebug
. (1895)
1.0.0-beta1
Mejoras
- Bump version to 1.0.0-beta1 to indicate graduation from being experimental. See 1846.
- Use CSS range syntax in media queries. (1833)
0.4.1
Corrección de fallos
- Remove requirement for both mobile and desktop URL metrics to be collected for
preconnect
links to be added. (1764)
0.4.0
Mejoras
- Incorporate media queries into preconnect links to account for whether embeds are in viewport. (1654)
- Serve unminified scripts when
SCRIPT_DEBUG
is enabled. (1643)
0.3.0
Mejoras
- Leverage URL Metrics to reserve space for embeds to reduce CLS. (1373)
- Avoid lazy-loading images and embeds unless there are URL Metrics for both mobile and desktop. (1604)
0.2.0
Mejoras
- Facilita el incrustar de Embed Optimizer. (1337)
- Aprovecha Optimization Detective para optimizar incrustaciones en Embed Optimizer. (1302)
0.1.2
Mejoras
- Mejora la calidad general del código con comprobaciones más estrictas del análisis estático. (775)
- Aumenta el requisito mínimo de PHP a 7.2. (1130)
Corrección de fallos
- Ocultar iframes incrustados en post con visibility:hidden en lugar de recortar. (1192)
0.1.1
- Utiliza el slug del plugin para la etiqueta del generador. (1103)
- Subir la versión mínima requerida de WP a 6.4. (1076)
0.1.0
- Versión inicial.