Maison interface Web tutoriel CSS Spécificité CSS : le poids derrière vos styles

Spécificité CSS : le poids derrière vos styles

Aug 20, 2024 am 06:36 AM

CSS Specificity: The Weight Behind Your Styles

Introduction

Imaginez CSS comme un défilé de mode où différents styles rivalisent pour attirer l'attention. Le gagnant ? Le style avec le plus de « poids » ou de spécificité. Dans cet article, nous allons percer le mystère derrière la spécificité CSS, en expliquant comment cela fonctionne et pourquoi c'est important.

Comprendre la spécificité CSS

La spécificité est une valeur numérique attribuée à chaque sélecteur CSS. Il détermine quelle règle de style l'emporte lorsque plusieurs styles sont appliqués au même élément. Considérez-le comme un concours de mode où la tenue la plus stylée est à l'honneur.

Comment calculer la spécificité

La spécificité est calculée en fonction de quatre facteurs :

  1. Styles en ligne : Styles directement appliqués à un élément à l'aide de l'attribut style. Ceux-ci ont la spécificité la plus élevée (1, 0, 0, 0).
  2. IDs : Sélecteurs utilisant la syntaxe #id. Chaque identifiant rapporte 100 points (0, 1, 0, 0).
  3. Classes, attributs et pseudo-classes : Les sélecteurs utilisant .class, [attribute] ou :pseudo-class contribuent 10 points chacun (0, 0, 1, 0).
  4. Éléments et pseudo-éléments : Les sélecteurs ciblant des éléments (comme p, div) ou des pseudo-éléments (comme ::before, ::after) contribuent 1 point chacun (0, 0, 0, 1).

Exemple :

  • #my-id .my-class:hover a une spécificité de (0, 1, 1, 0) soit 110 points.
  • .my-class p a une spécificité de (0, 0, 1, 1) ou 11 points.

La règle avec la spécificité la plus élevée l'emporte.

L'impact de la spécificité

  • Remplacement des styles : Des sélecteurs plus spécifiques peuvent remplacer des sélecteurs moins spécifiques. Par exemple, un style en ligne remplacera toujours un style défini dans une feuille de style.
  • Conséquences inattendues : Une spécificité élevée peut rendre difficile le remplacement des styles, conduisant à des résultats inattendus.
  • Débogage : Comprendre la spécificité permet d'identifier les conflits de style et de les résoudre efficacement.

Exemples concrets

Disons que vous avez un bouton avec les styles suivants :

button {
  color: blue;
}

.primary-button {
  color: red;
}

#important-button {
  color: green;
}
Copier après la connexion

Si le bouton a le bouton principal de classe et le bouton important d'ID, la couleur verte de l'ID sera appliquée car elle a la spécificité la plus élevée.

Conclusion

La spécificité CSS peut être un sujet complexe, mais la comprendre est crucial pour maîtriser le CSS. En comprenant comment la spécificité est calculée et son impact sur l'application du style, vous serez mieux équipé pour créer des styles bien structurés et prévisibles.

Dans le prochain article, nous approfondirons les couches CSS, un outil puissant pour gérer la spécificité et améliorer votre architecture CSS.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Ajout d'ombres de boîte aux blocs et éléments WordPress Ajout d'ombres de boîte aux blocs et éléments WordPress Mar 09, 2025 pm 12:53 PM

Ajout d'ombres de boîte aux blocs et éléments WordPress

Créez un formulaire de contact JavaScript avec le cadre Smart Forms Créez un formulaire de contact JavaScript avec le cadre Smart Forms Mar 07, 2025 am 11:33 AM

Créez un formulaire de contact JavaScript avec le cadre Smart Forms

Créer un éditeur de texte en ligne avec l'attribut satisfaistable Créer un éditeur de texte en ligne avec l'attribut satisfaistable Mar 02, 2025 am 09:03 AM

Créer un éditeur de texte en ligne avec l'attribut satisfaistable

Travailler avec GraphQL Caching Travailler avec GraphQL Caching Mar 19, 2025 am 09:36 AM

Travailler avec GraphQL Caching

Faire votre première transition Svelte personnalisée Faire votre première transition Svelte personnalisée Mar 15, 2025 am 11:08 AM

Faire votre première transition Svelte personnalisée

Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques Mar 08, 2025 am 09:45 AM

Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Mar 04, 2025 am 10:22 AM

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres)

Téléchargement de fichiers avec Multer dans Node.js et Express Téléchargement de fichiers avec Multer dans Node.js et Express Mar 02, 2025 am 09:15 AM

Téléchargement de fichiers avec Multer dans Node.js et Express

See all articles