Précharger les polices Web pour améliorer la vitesse de chargement

Garima Mimani
Garima Mimani

Cet atelier de programmation vous explique comment précharger des polices Web à l'aide de rel="preload" pour supprimer tout flash de texte sans style (FOUT).

Mesurer

Commencez par mesurer les performances du site Web avant d'ajouter des optimisations.

  1. Pour prévisualiser le site, appuyez sur Afficher l'application. Appuyez ensuite sur Plein écran plein écran
  2. Appuyez sur Ctrl+Maj+J (ou Cmd+Option+J sur Mac) pour ouvrir les outils de développement.
  3. Cliquez sur l'onglet Lighthouse.
  4. Assurez-vous que la case Performances est cochée dans la liste Catégories.
  5. Cliquez sur le bouton Générer un rapport.

Le rapport Lighthouse généré indique la séquence d'extraction des ressources sous Latence maximale du chemin critique.

Des polices Web sont présentes dans la chaîne de requêtes critique.

Dans l'audit ci-dessus, les polices Web font partie de la chaîne de requêtes critique et sont récupérées en dernier. La chaîne de requêtes critiques représente l'ordre des ressources qui sont hiérarchisées et récupérées par le navigateur. Dans cette application, les polices Web (Pacfico et Pacifico-Bold) sont définies à l'aide de la règle @font-face et constituent la dernière ressource récupérée par le navigateur dans la chaîne de requêtes critique. En règle générale, les polices Web sont chargées en différé, ce qui signifie qu'elles ne sont chargées que lorsque les ressources critiques sont téléchargées (CSS, JS).

Voici la séquence des ressources récupérées dans l'application:

Les polices Web sont chargées de façon différée.

Préchargement des polices Web

Pour éviter l'effet FOUT, vous pouvez précharger les polices Web qui sont requises immédiatement. Ajoutez l'élément Link de cette application en haut du document:

<head>
 <!-- ... -->
 <link rel="preload" href="/assets/Pacifico-Bold.woff2" as="font" type="font/woff2" crossorigin>
</head>

Les attributs as="font" type="font/woff2" indiquent au navigateur de télécharger cette ressource sous forme de police et aident à hiérarchiser la file d'attente de ressources.

L'attribut crossorigin indique si la ressource doit être extraite avec une requête CORS, car la police peut provenir d'un autre domaine. Sans cet attribut, la police préchargée est ignorée par le navigateur.

Étant donné que Pacifico-Bold est utilisé dans l'en-tête de la page, nous avons ajouté une balise de préchargement pour la récupérer encore plus rapidement. Il n'est pas important de précharger la police Pacifico.woff2, car elle applique un style au texte qui se trouve en dessous de la ligne de flottaison.

Actualisez l'application et exécutez à nouveau Lighthouse. Consultez la section Latence maximale du chemin critique.

La police Web Pacifico-Bold est préchargée et supprimée de la chaîne de requête

Notez que Pacifico-Bold.woff2 est supprimé de la chaîne de requêtes critique. Il est récupéré plus tôt dans l'application.

La police Web Pacifico-Bold est préchargée

Grâce au préchargement, le navigateur sait qu'il doit télécharger ce fichier plus tôt. Il est important de noter que s'il n'est pas utilisé correctement, le préchargement peut nuire aux performances en effectuant des requêtes inutiles pour des ressources qui ne sont pas utilisées.