Selettori CSS: Guida Completa
I selettori CSS sono uno degli elementi fondamentali del CSS, poiché permettono di selezionare e stilizzare elementi HTML specifici. Esistono diversi tipi di selettori, ognuno con la propria sintassi e utilità , che ti consentono di applicare stili a elementi singoli, gruppi di elementi, o elementi basati su attributi, stato e posizione all’interno del DOM. In questa guida, esploreremo i vari tipi di selettori CSS, con esempi pratici e best practices per creare fogli di stile efficienti e manutenibili.
1. Tipi di Selettori CSS
1.1. Selettore Universale (*
)
Il selettore universale (*
) seleziona tutti gli elementi all’interno di un documento.
Esempio:
* {
margin: 0;
padding: 0;
}
In questo esempio, tutti gli elementi della pagina avranno margini e padding azzerati.
1.2. Selettori di Tipo
I selettori di tipo selezionano tutti gli elementi di un determinato tipo (tag HTML).
Esempio:
p {
font-size: 16px;
color: #333;
}
In questo esempio, tutti gli elementi <p>
avranno un font di 16px e un colore del testo #333.
1.3. Selettori di Classe
I selettori di classe selezionano elementi che hanno una determinata classe, utilizzando il punto (.
) seguito dal nome della classe.
Esempio:
.button {
background-color: #4caf50;
color: white;
padding: 10px 20px;
}
In questo esempio, tutti gli elementi con la classe .button
avranno il colore di sfondo #4caf50, testo bianco e un padding di 10px 20px.
1.4. Selettori ID
I selettori ID selezionano un elemento unico per ID, utilizzando il simbolo del cancelletto (#
) seguito dal nome dell’ID.
Esempio:
#header {
background-color: #f0f0f0;
padding: 20px;
}
In questo esempio, l’elemento con ID header
avrà uno sfondo grigio chiaro e un padding di 20px.
1.5. Selettori Attributo
I selettori attributo selezionano elementi in base alla presenza o al valore di un attributo.
Esempio:
input[type="text"] {
border: 1px solid #ccc;
padding: 5px;
}
In questo esempio, tutti gli <input>
di tipo text
avranno un bordo grigio e un padding di 5px.
1.6. Selettori di Discendenza
I selettori di discendenza selezionano elementi che sono discendenti (non necessariamente figli diretti) di un altro elemento.
Esempio:
ul li {
list-style-type: square;
}
In questo esempio, tutti gli elementi <li>
all’interno di <ul>
avranno uno stile di elenco quadrato.
1.7. Selettori Figlio
I selettori figlio (>
) selezionano solo gli elementi che sono figli diretti di un altro elemento.
Esempio:
div > p {
color: #666;
}
In questo esempio, solo i <p>
che sono figli diretti di un <div>
avranno un colore del testo #666.
1.8. Selettori Fratello
I selettori fratello adiacente (+
) e fratello generale (~
) selezionano elementi che sono rispettivamente il fratello immediatamente successivo o tutti i fratelli successivi di un altro elemento.
Esempio:
h1 + p {
margin-top: 0;
}
h1 ~ p {
color: #777;
}
In questo esempio, il primo <p>
che segue un <h1>
avrà un margine superiore di 0, mentre tutti i <p>
che seguono un <h1>
avranno un colore del testo #777.
1.9. Selettori di Gruppo
I selettori di gruppo selezionano più elementi che condividono gli stessi stili.
Esempio:
h1,
h2,
h3 {
font-family: Arial, sans-serif;
color: #333;
}
In questo esempio, gli elementi <h1>
, <h2>
, e <h3>
avranno lo stesso font e colore del testo.
1.10. Selettori Pseudo-classi
Le pseudo-classi selezionano elementi in base al loro stato o posizione nel DOM, come :hover
, :nth-child()
, :first-child
, ecc.
Esempio:
a:hover {
color: #ff5722;
}
li:nth-child(odd) {
background-color: #f9f9f9;
}
In questo esempio, i link cambieranno colore quando l’utente ci passa sopra con il mouse, e gli <li>
in posizione dispari avranno uno sfondo grigio chiaro.
1.11. Selettori Pseudo-elementi
I pseudo-elementi selezionano parti di un elemento, come ::before
, ::after
, ::first-letter
, e ::first-line
.
Esempio:
p::first-line {
font-weight: bold;
}
p::after {
content: " - Fine del paragrafo";
font-style: italic;
}
In questo esempio, la prima riga di ogni paragrafo sarà in grassetto e verrà aggiunto del testo in corsivo alla fine di ogni paragrafo.
2. Specificità dei Selettori
La specificità dei selettori determina quale stile verrà applicato quando più selettori corrispondono allo stesso elemento. La specificità si basa su un sistema a punti:
- ID Selettori: 100 punti
- Classi, pseudo-classi, attributi: 10 punti ciascuno
- Selettori di tipo e pseudo-elementi: 1 punto ciascuno
- Selettore universale (
*
): 0 punti
Esempio:
#menu .item {
color: red;
}
.item {
color: blue;
}
In questo esempio, il primo selettore ha una specificità maggiore (110) rispetto al secondo (10), quindi gli elementi con classe .item
all’interno di un elemento con ID #menu
avranno il testo rosso.
3. Best Practices per l’Uso dei Selettori
3.1. Mantieni i Selettori Semplici
Usa selettori semplici per mantenere il CSS leggibile e ridurre i problemi di specificità . Evita selettori troppo complessi che possono essere difficili da gestire.
3.2. Evita l’Uso eccessivo di ID
Usa le classi piuttosto che gli ID per la maggior parte delle selezioni, poiché le classi sono più flessibili e riutilizzabili.
3.3. Sfrutta i Selettori di Gruppo
Utilizza i selettori di gruppo per ridurre la ripetizione del codice e mantenere il CSS conciso.
3.4. Attenzione alla SpecificitÃ
Gestisci la specificità con attenzione per evitare problemi in cui gli stili non vengono applicati come previsto. Preferisci l’uso di classi rispetto a ID o selettori troppo specifici.
3.5. Usa Pseudo-classi e Pseudo-elementi in Modo Efficiente
Le pseudo-classi e i pseudo-elementi sono strumenti potenti per stilizzare stati e parti specifiche degli elementi. Usali per migliorare l’interattività e l’estetica senza aggiungere markup extra.
3.6. Combina i Selettori per un Controllo Maggiore
Combina i selettori di classe, tipo e attributo per ottenere un controllo preciso sugli elementi, evitando di sovraccaricare la specificità .
4. Conclusione
I selettori CSS sono alla base della creazione di layout e stili efficaci nelle pagine web. Comprendere i vari tipi di selettori e come utilizzarli correttamente ti permette di scrivere CSS più efficiente, mantenibile e potente. Seguendo le best practices e sperimentando con selettori semplici e complessi, puoi ottenere un controllo totale sull’aspetto e la funzionalità delle tue pagine web.