:has() - Sélecteur CSS
Résumé des caractéristiques du sélecteur :has()
Description de la pseudo-classe :has().
La pseudo-classe :has() cible les éléments en fonction de leur(s) enfant(s).
Par exemple, le sélecteur td:has(img) cible les cellules de tableau qui contiennent au moins une image.
Plusieurs sélecteurs peuvent être énumérés dans les parenthèses de :has(). Cette liste est tolérante, ce qui signifie
que, si la syntaxe de certains des sélecteurs énumérés est incorrecte, cela n'invalide pas l'expression complète : :has()
traite le reste de la liste en ignorant les sélecteurs erronés.
:has() permet donc de cibler un élément en fonction de son contenu. Ne confondez pas les deux syntaxes suivantes :
td img cible les images contenues dans une cellule,
td:has(img) cible les cellules qui contiennent une image.
Exemples d'utilisation de :has().
Ces exemples ne fonctionneront pas sur puisque ce navigateur ne traite toujours pas la pseudo-classe
:has() (2022).
Cibler les cellules d'un tableau sauf la dernière de chaque ligne.
Le code CSS utilisé pour cet exemple cible les cellules qui sont suivies d'une autre cellule, autrement dit toutes les cellules sauf la dernière de chaque ligne.
| A1 | B1 | C1 | D1 | E1 |
| A2 | B2 | C2 | D2 | E2 |
Cibler les formulaires qui ont une saisie de mot de passe.
L'objectif de cet exemple est d'ajouter un message (ici en rouge) aux formulaires qui comportent une saisie de mot de passe,
c'est à dire une balise input type="password" /.
Le sélecteur est un peu compliqué car il fait intervenir également le pseudo-élément ::after.
Compatibilité des navigateurs.
La prise en charge de la pseudo-classe :has() n'est toujours pas assurée par de nombreux navigateurs, dont .
:has()Navigateurs sur ordinateurs :
Navigateurs sur mobiles :
Navigateurs obsolètes ou marginaux :

Internet Explorer

Baidu Browser

QQ Browser

Opéra Mobile

Firefox

Chrome

Safari

Edge

Opéra

Chrome pour Androïd

Safari sur IOS

Samsung Internet

UC Browser pour Androïd

Androïd Brower

Firefox pour Androïd

KaiOS Browser

Opéra mini
Historique de la pseudo-classe :has().
-
Sélecteurs - Niveau 4
Introduction de la pseudo-classe:has()dans la spécification des sélecteurs niveau 4.29 Septembre 2011Document de travail.
Autres pseudo-classes conditionnelles.
:is().is().


