A partir de Chrome 83, se pueden combinar link rel="preload" y font-display: opcional para quitar por completo el bloqueo de diseño.
Al optimizar los ciclos de renderización, Chrome 83 elimina los cambios de diseño cuando se precarga fuentes opcionales.
Combinar <link rel="preload">
con font-display: optional
es la forma más eficaz de garantizar que no se bloquee el diseño cuando se renderizan fuentes personalizadas.
Compatibilidad del navegador
Consulta los datos de MDN para obtener información actualizada sobre la compatibilidad en varios navegadores:
Renderización de fuentes
El cambio de diseño, o rediseño, ocurre cuando un recurso de una página web cambia de forma dinámica, lo que genera un "cambio" del contenido. La recuperación y renderización de fuentes web pueden provocar cambios de diseño directamente de una de estas dos maneras:
- Una fuente de resguardo se intercambia por una fuente nueva ("flash de texto sin estilo")
- El texto "Invisible" se muestra hasta que se representa una nueva fuente en la página ("destello de texto invisible")
La propiedad font-display
de CSS proporciona una forma de modificar el comportamiento de renderización de las fuentes personalizadas a través de un rango de diferentes valores admitidos (auto
, block
, swap
, fallback
y optional
). La elección del valor que se debe usar depende del comportamiento preferido para las fuentes cargadas de forma asíncrona. Sin embargo, cada uno de estos valores admitidos puede activar el nuevo diseño de una de las dos maneras mencionadas anteriormente, hasta ahora.
Fuentes opcionales
La propiedad font-display
usa un cronograma de tres períodos para controlar las fuentes que deben descargarse antes de que se puedan renderizar:
- Bloquear: Renderiza el texto "invisible", pero cambia a la fuente web en cuanto termina de cargarse.
- Swap: Renderiza texto con una fuente de sistema de resguardo, pero cambia a la fuente web en cuanto termine de cargarse.
- Error: Renderiza texto con una fuente de sistema de resguardo.
Anteriormente, las fuentes designadas con font-display: optional
tenían un período de bloqueo de 100 ms y sin período de intercambio. Eso significa que el texto "invisible" se muestra muy brevemente antes de cambiar a una fuente de resguardo. Si la fuente no se descarga en 100 ms, se usa la fuente de resguardo y no se produce ningún intercambio.
Sin embargo, en el caso de que la fuente se descargue antes de que finalice el período de bloqueo de 100 ms, la fuente personalizada se renderizará y se usará en la página.
Chrome vuelve a renderizar la página dos veces en ambos casos, independientemente de si se usa la fuente de resguardo o si la fuente personalizada termina de cargarse a tiempo. Como resultado, se produce un leve parpadeo del texto invisible y, en los casos en que se renderiza una fuente nueva, se bloquea el diseño que mueve parte del contenido de la página. Esto ocurre incluso si la fuente se almacena en la caché de disco del navegador y puede cargarse mucho antes de que finalice el período de bloqueo.
Llegaron las optimizaciones en Chrome 83 para quitar por completo el primer ciclo de renderización de las fuentes opcionales que se precargan con <link rel="preload'>
.
sino que se bloquea la renderización hasta que la fuente personalizada termina de cargarse o hasta que transcurre un período determinado. Este tiempo de espera se establece en 100 ms, pero es posible que cambie en un futuro cercano para optimizar el rendimiento.
La precarga de fuentes opcionales en Chrome quita la posibilidad de bloqueos de diseño y flash de texto sin estilo. Esto coincide con el comportamiento requerido que se especifica en el nivel 4 del módulo de fuentes de CSS, en el que las fuentes opcionales nunca deben cambiar el diseño y los usuarios-agentes pueden, en cambio, retrasar la renderización durante un período adecuado.
Si bien no es necesario precargar una fuente opcional, mejora considerablemente las posibilidades de que se cargue antes del primer ciclo de renderización, en especial, si aún no se almacenó en la caché del navegador.
Conclusión
Al equipo de Chrome le interesa conocer tu experiencia con la precarga de fuentes opcionales con estas nuevas optimizaciones implementadas. Informa un problema si tienes algún inconveniente o si quieres descartar sugerencias de funciones.