Reporter les CSS non critiques

Demián Renzulli
Demián Renzulli

Les fichiers CSS sont des ressources qui bloquent l'affichage : ils doivent être chargés et traités avant que le navigateur n'affiche la page. L'affichage des pages Web contenant des feuilles de style inutilement volumineuses prend plus de temps.

Dans ce guide, vous allez apprendre à différer les CSS non critiques afin d'optimiser le chemin d'affichage critique et d'améliorer la méthode First Contentful Paint (FCP).

Exemple: chargement CSS non optimal

L'exemple suivant contient un accordéon avec trois paragraphes de texte masqués, chacun stylisé avec une classe différente:

Cette page demande un fichier CSS avec huit classes, mais elles ne sont pas toutes nécessaires pour afficher le contenu "visible".

L'objectif de ce guide est d'optimiser cette page pour que seuls les styles essentiels soient chargés de manière synchrone, tandis que les autres (y compris les styles de paragraphe) sont chargés de manière non bloquante.

Mesurer

Exécutez Lighthouse sur la page et accédez à la section Performances.

Le rapport affiche la métrique First Contentful Paint avec une valeur de "1s", ainsi que l'opportunité Eliminate block resources (Éliminer les ressources bloquant l'affichage), pointant vers le fichier style.css:

Rapport Lighthouse pour la page non optimisée, affichant le FCP "1" et "Éliminer les ressources bloquantes" sous "Opportunités"
Le rapport Lighthouse suggère de simplifier votre feuille de style pour accélérer le chargement de la page.

Pour voir comment ce CSS bloque l'affichage:

  1. Ouvrez la page dans Chrome.
  2. Appuyez sur Control+Shift+J (ou Command+Option+J sur Mac) pour ouvrir les outils de développement.
  3. Cliquez sur l'onglet Performances.
  4. Dans le panneau "Performances", cliquez sur Actualiser.

Dans la trace obtenue, vous verrez que le repère FCP est placé immédiatement après la fin du chargement du CSS:

Trace des performances des outils de développement pour la page non optimisée, montrant le FCP qui commence après le chargement du CSS
Sur la page de démonstration non optimisée, le FCP ne peut pas se produire tant que le chargement du CSS n'est pas terminé.

Cela signifie que le navigateur doit attendre que tous les CSS se chargent et soient traités avant d'afficher un seul pixel à l'écran.

Optimisation

Pour optimiser cette page, vous devez savoir quelles classes sont considérées comme essentielles. Pour le déterminer, utilisez l'outil de couverture:

  1. Dans les outils de développement, ouvrez le menu de commandes en appuyant sur Control+Shift+P ou Command+Shift+P (Mac).
  2. Saisissez "Couverture" et sélectionnez Afficher la couverture.
  3. Cliquez sur Actualiser pour actualiser la page et commencer à enregistrer la couverture.
Couverture du fichier CSS, affichant 55,9% des octets inutilisés.
Le rapport de couverture indique la part de votre CSS utilisée dans le chargement initial de la page.

Double-cliquez sur le rapport pour afficher les détails:

  • Les classes indiquées en vert sont essentielles. Le navigateur en a besoin pour afficher le contenu visible, y compris les boutons de titre, de sous-titre et d'accordéon.
  • Les classes en rouge ne sont pas critiques et n'affectent que le contenu qui n'est pas immédiatement visible, comme les paragraphes masqués.

Grâce à ces informations, optimisez votre CSS afin que le navigateur puisse commencer à traiter les styles critiques immédiatement après le chargement de la page et reporter les CSS non essentiels pour plus tard:

  1. Extrayez les définitions de classe marquées en vert dans le rapport de couverture, puis placez ces classes dans un bloc <style> en haut de la page:

    <style type="text/css">
    .accordion-btn {background-color: #ADD8E6;color: #444;cursor: pointer;padding: 18px;width: 100%;border: none;text-align: left;outline: none;font-size: 15px;transition: 0.4s;}.container {padding: 0 18px;display: none;background-color: white;overflow: hidden;}h1 {word-spacing: 5px;color: blue;font-weight: bold;text-align: center;}
    </style>
    
  2. Chargez le reste des classes de manière asynchrone en appliquant le modèle suivant:

    <link rel="preload" href="styles.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <noscript><link rel="stylesheet" href="styles.css"></noscript>
    

Il ne s'agit pas de la méthode standard pour charger CSS. Le principe est le suivant :

  • link rel="preload" as="style" demande la feuille de style de manière asynchrone. Pour en savoir plus sur preload, consultez le guide Précharger les éléments critiques.
  • L'attribut onload dans link permet au navigateur de traiter le CSS une fois le chargement de la feuille de style terminé.
  • L'annulation de la valeur du gestionnaire onload après son utilisation permet à certains navigateurs d'éviter de le rappeler lorsqu'ils changent l'attribut rel.
  • La référence à la feuille de style dans l'élément noscript fournit une solution de remplacement pour les navigateurs qui n'exécutent pas JavaScript.

La page obtenue ressemble exactement à la version précédente, même lorsque la plupart des styles se chargent de manière asynchrone. Voici à quoi ressemblent les styles intégrés et la requête asynchrone adressée au fichier CSS dans le fichier HTML:

Surveiller

Utilisez les outils de développement pour exécuter une autre trace Performance sur la page optimisée.

Le repère FCP apparaît avant que la page demande le CSS. Le navigateur n'a donc pas besoin d'attendre le chargement du CSS pour afficher la page:

Trace des performances des outils de développement pour la page optimisée, montrant le FCP qui commence avant le chargement du CSS
Sur la page optimisée, le FCP peut commencer avant le chargement de la feuille de style.

Pour finir, exécutez Lighthouse sur la page optimisée.

Dans le rapport, vous constaterez que la page FCP a été réduite de 0,2 s (soit une amélioration de 20 %):

Rapport Lighthouse, indiquant une valeur FCP de &quot;0,8 s&quot;
Nouveau FCP réduit

La suggestion Éliminer les ressources qui bloquent l'affichage n'apparaît plus sous Opportunités, mais se trouve à la place dans la section Audits réussis:

Rapport Lighthouse, indiquant &quot;Éliminer les ressources bloquantes&quot; dans la section &quot;Audits réussis&quot;.
La page réussit l'audit des ressources bloquantes.

Étapes suivantes et références

Dans ce guide, vous avez appris à différer les CSS non critiques en extrayant manuellement le code inutilisé dans la page. Pour les environnements de production plus complexes, le guide Extraire les fichiers CSS critiques couvre certains des outils les plus populaires permettant d'extraire les fichiers CSS critiques et inclut un atelier de programmation pour voir comment ils fonctionnent en pratique.