Cet atelier de programmation vous explique comment précharger des polices Web à l'aide de rel="preload"
pour supprimer tout flash de texte non stylisé (FOUT).
Mesurer
Commencez par mesurer les performances du site Web avant d'effectuer des optimisations.
- Pour prévisualiser le site, appuyez sur Afficher l'application, puis sur Plein écran .
- Appuyez sur Ctrl+Maj+J (ou Cmd+Option+J sur Mac) pour ouvrir DevTools.
- Cliquez sur l'onglet Lighthouse (Phare).
- Assurez-vous que la case Performances est cochée dans la liste Catégories.
- Cliquez sur le bouton Générer un rapport.
Le rapport Lighthouse généré affiche la séquence de récupération des ressources sous Latence maximale du chemin critique.
Dans l'audit ci-dessus, les polices Web font partie de la chaîne de requêtes critiques et sont récupérées en dernier. La chaîne de requêtes critiques représente l'ordre des ressources qui sont priorisées et extraites 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 critiques. En règle générale, les polices Web sont chargées de manière différée, ce qui signifie qu'elles ne sont pas chargées tant que les ressources critiques ne sont pas téléchargées (CSS, JS).
Voici la séquence des ressources récupérées dans l'application:
Précharger les polices Web
Pour éviter les erreurs de police, vous pouvez précharger les polices Web requises immédiatement. Ajoutez l'élément Link
de cette application en tête 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 en tant que police et aident à hiérarchiser la file d'attente des ressources.
L'attribut crossorigin
indique si la ressource doit être récupérée 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 l'extraire encore plus rapidement. Il n'est pas important de précharger la police Pacifico.woff2, car elle stylise le texte situé sous la ligne de flottaison.
Rechargez l'application et exécutez Lighthouse à nouveau. Consultez la section Latence maximale du chemin critique.
Notez que Pacifico-Bold.woff2
est supprimé de la chaîne de requêtes critiques. Il est extrait plus tôt dans l'application.
Avec le préchargement, le navigateur sait qu'il doit télécharger ce fichier plus tôt. Notez que si elle n'est pas utilisée correctement, la précharge peut nuire aux performances en envoyant des requêtes inutiles pour des ressources qui ne sont pas utilisées.