Propriétés et spécificité CSS héritées
Lorsque plusieurs déclarations CSS ciblent le même élément, celle avec la spécificité la plus élevée est prioritaire. Les règles de calcul de spécificité CSS sont bien documentées dans la recommandation W3. Cependant, la manière dont les propriétés héritées s'intègrent dans ce schéma est moins claire.
L'héritage introduit une couche de complexité car une propriété héritée combine efficacement la spécificité de son élément parent avec la sienne. Cela signifie qu'une propriété héritée d'un élément parent très spécifique peut remplacer une propriété directement appliquée avec une spécificité moindre.
Considérez l'exemple suivant :
<h2 class="all_red_text">This should be black</h2>
h2 { color: black; } .all_red_text { color: red; }
Dans cet exemple, le La propriété color est héritée de la propriété
Selon les règles de spécificité CSS, le sélecteur le plus spécifique (le sélecteur h2 dans ce cas) doit avoir priorité. Cependant, comme la propriété color est héritée, elle a effectivement la spécificité de l'élément parent (0,1,0).
Par conséquent, la propriété color héritée de l'élément parent remplace la propriété color directement appliquée. . Le texte à l'intérieur de l'élément h2 est noir au lieu de rouge.
Ce comportement peut prêter à confusion au début, mais il constitue une partie importante du fonctionnement de l'héritage CSS. En comprenant comment les propriétés héritées affectent la spécificité, vous pouvez éviter des résultats inattendus et garantir que votre code CSS se comporte comme prévu.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!