--- title: CSS Coverage slug: orphaned/Tools/CSS_Coverage translation_of: Tools/CSS_Coverage original_slug: Outils/CSS_Coverage ---
{{ToolsSidebar}}

Cette fonctionnalité est expérimentale et n'est pas encore disponible dans Firefox.

Le CSS Coverage est un ensemble de commandes pour les outils de développement de Firefox qui aide à améliorer du CSS désordonné en mettant en évidence le CSS qui n'est pas "utilisé" et en indiquant les parties du fichier CSS nécessaires au rendu initial.

Cet outil est quelque peu expérimental, car la définition "d'utilisation" du CSS est compliquée. Ce guide a pour ambition d'expliquer comment cet outil fonctionne.

Cet outil est généralement utilisé de la façon suivante :

Une autre commande ("csscoverage oneshot") permet de lancer ("csscoverage start; csscoverage stop").

Que veut dire "utiliser" ?

TL;DR :

Le CSS coverage vérifie que le sélecteur tag#id.class dans l'exemple ci-dessous, existe dans un ensemble de pages web :

@media thing {
  tag#id.class:hover {
    foo: bar;
  }
}

Pourquoi ?

Supposons que le CSS possède ce genre de propriété :

<style>
  span:hover {
    color: purple;
  }
</style>

<span>Test</span>

Si durant ce test, la souris n'est pas entrée dans le <span>, est-ce que la règle a été utilisée ?

Techniquement parlant, la règle span:hover n'a pas été utilisée dans le sens ou le mot "Test" n'a jamais été coloré en violet. Cependant, Le CSS coverage se concentre principalement à voir quelles règles sont pertinentes ou non pour la page. Dans ce cas, span:hover est visiblement pertinent pour la page.

Supposons également que le CSS possède ce genre de propriété :

<style>
  @media tv {
    span {
      color: purple;
    }
  }
</style>

<span>Test</span>

Devrait-il être obligatoire de se connecter depuis une télévision pour mesurer la pertinence de cette règle ?

Mais "l'utilisation" n'est pas seulement une affaire de pertinence...
Est-ce que la règle suivante est pertinente ?

<style>
  span { }
</style>

<span>Test</span>

Il est possible d'affirmer que cette règle n'est pas pertinente, car elle n'a pas d'effet sur la page et peut donc être retirée sans danger.

Cependant qu'en est-il du code suivant :

<style>
  span {
    -o-text-curl: minor;
  }
</style>

<span>Test</span>

Savoir si cette règle est utilisée ou non requiert l'utilisation d'un moteur de recherche et des compétences analytiques, et peut être même des connaissances sur les versions des navigateurs supportés par le site. Ceci est donc considéré hors de portée de cet outil, du moins jusqu'à la singularité.

Cela explique également pourquoi la règle appliquée aux div dans l'exemple suivant est considéré comme "utilisée"

<style>
  div { color: red; }
  span { color: blue; }
</style>

<div><span>Test</span></div>

Il est possible d'affirmer que la règle div n'est pas utilisée puisqu'elle n'affecte pas le rendu final de la page. Cependant si l'on considère la définition alternative suivante :

<style>
  div { color: red; border: none; }
  span { color: blue; }
</style>

Il est alors difficile de savoir si la règle de bordure est utilisée, et il existe beaucoup d'autres variations. L'opacité, la visibilité et les conversions de couleurs par exemple compliquent encore la définition "d'utilisation". Pour garder une définition simple, "utilisée" signifie que le sélecteur correspond ç au moins un élément.

Si une feuille de style incluse dans un test contient une règle qui ne s'applique que pour une page particulière qui n'a pas été visitée lors du Test, alors bien évidemment cette règle sera marquée comme "non-utilisée" malgré le fait qu'il existe des moments ou cette règle est utilisée. Il est donc recommandé de doubler les vérifications avant d'enlever des règles des fichiers CSS.

Avertissements

Il est à noter que :

Bugs

La résolution de certains bugs importants est actuellement en travail :

 

Alternatives

Il y plusieurs autres outils qui peuvent vous aider à trouver du CSS inutilisé, sans avoir besoin d'utiliser Firefox.