Selectorii vizează care elemente unei reguli i se aplică. Ei variază de la simplu (după etichetă) la combinatoare puternice.
css
/* Basic selectors */
p { } /* type: all <p> */
.card { }
{ }
* { }
{ }
Selectorii vizează care elemente unei reguli i se aplică. Ei variază de la simplu (după etichetă) la combinatoare puternice.
/* 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 */
Diferența dintre spațiu (descendent) și > (copil direct) contează: .menu li se potrivește și cu li-urile profund cuibărite, în timp ce .menu > li se potrivește doar cu nivelul superior.
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 */
Selectorii sunt modul în care conectați stilurile la marcaj.
Stăpânirea claselor (muncitorul), combinatoarelor (pentru relații) și pseudo-claselor structurale/de stare vă permite să țintească cu precizie fără a adăuga clase suplimentare peste tot — iar :is()/:has() moderne fac țintirea complexă concisă.
Preferați clasele în loc de ids/cuibărire profundă pentru a menține specificitatea gestionabilă.