📢 Nuovo Corso Laravel API disponibile!

Principio Specificità in CSS

Cos’è la Specificità?

Se ci sono due o più regole CSS che puntano allo stesso elemento, il selettore con il valore di specificità più alto “vince” e la sua dichiarazione di stile verrà applicata a quell’elemento HTML.

Pensa alla specificità come a un punteggio che determina quale dichiarazione di stile viene alla fine applicata a un elemento.

Guarda gli esempi seguenti:

<html>
<head>
<style>
p {
color: green;
}
</style>
</head>
<body>
<p>Bellissimo pargrafo!</p>
</body>
</html>
<html>
<head>
<style>
.classe1 {
color: red;
}
p {
color: green;
}
</style>
</head>
<body>
<p class="classe1">Bellissimo pargrafo!</p>
</body>
</html>
<html>
<head>
<style>
.classe1 {
color: red;
}
p {
color: green;
}
</style>
</head>
<body>
<p class="classe1" style="color:purple;">Bellissimo pargrafo!</p>
</body>
</html>

Gerarchia della Specificità

Ogni selettore CSS ha il suo posto nella gerarchia della specificità.

Ci sono quattro categorie che definiscono il livello di specificità di un selettore:

  • Stili inline: <h1 style="color: red;">
  • ID: #navbar
  • Classi, pseudo-classi, selettori di attributi: .classe, :hover, [src]
  • Elementi e pseudo-elementi: h1, ::before ::after

Come Calcolare la Specificità?

Inizia da 0, aggiungi 100 per ogni valore ID, aggiungi 10 per ogni valore di classe (o pseudo-classe o selettore di attributi), aggiungi 1 per ogni selettore di elemento o pseudo-elemento.

Lo stile inline ottiene un valore di specificità di 1000 ed è sempre dato la massima priorità!

C’è un’eccezione a questa regola: la regola !important sovrascrive qualsiasi stile, anche quello inline.

La tabella qui sotto mostra alcuni esempi su come calcolare i valori di specificità:

SelettoreValore SpecificitàPunteggio
h111
.classe1010
h1.classe111 + 11
#id100100
h1#id1011 + 100
<h1 style="color: red;">10001000
h1.classe1.classe2211 + 10 + 10

Il selettore con il valore di specificità è quello che avrà effetto sull’elemento sovrascrivendo le altre regole.