I selettori identificano gli elementi a cui si applica una regola. Vanno da quelli semplici (per tag) a combinatori potenti.
css
/* Basic selectors */
p { } /* type: all <p> */
.card { }
{ }
* { }
{ }
I selettori identificano gli elementi a cui si applica una regola. Vanno da quelli semplici (per tag) a combinatori potenti.
/* Basic selectors */
p { } /* type: all <p> */
.card { }
{ }
* { }
{ }
.menu li { } /* descendant: any li INSIDE .menu (any depth) */
.menu > li { } /* child: only DIRECT children li */
h2 + p { } /* adjacent sibling: the p immediately AFTER an h2 */
h2 ~ p { } /* general sibling: all p siblings after an h2 */
La differenza tra lo spazio (discendente) e > (figlio diretto) è importante: .menu li corrisponde anche agli li annidati in profondità, mentre .menu > li corrisponde solo al livello superiore.
a:hover { } /* state: while hovered */
li:first-child { } /* structural: the first li */
li:nth-child(2n){ } /* every even li */
p::first-line { } /* pseudo-element: the first rendered line */
h1, h2, h3 { } /* apply to all three */
:is(h1, h2) a { } /* :is() shortens long selector lists */
.card:has(img) { } /* :has() — a parent that CONTAINS an img */
I selettori sono il modo in cui connetti gli stili al markup.
Padroneggiare le classi (il principale strumento), i combinatori (per le relazioni) e le pseudo-classi strutturali/di stato ti consente di mirare con precisione senza aggiungere classi extra ovunque — e i moderni :is()/:has() rendono il targeting complesso conciso.
Preferirisci le classi rispetto agli id/annidamento profondo per mantenere la specificità gestibile.