recherche
Maisoninterface Webtutoriel CSSLes sélecteurs CSS peuvent-ils cibler des éléments en fonction de l'état d'autres éléments ?

Can CSS Selectors Target Elements Based on the State of Other Elements?

Comment sélectionner des éléments en fonction de l'état d'autres éléments avec CSS

Introduction

Le ciblage d’éléments spécifiques a toujours été un aspect fondamental du CSS. Cependant, des complexités surviennent lorsque nous devons styliser des éléments en fonction de l'état d'autres éléments de la page. Cet article explore les limites des sélecteurs CSS actuels et présente une solution potentielle issue d'une norme à venir.

Limitations des sélecteurs CSS actuels

Les sélecteurs CSS ont plusieurs limitations dans la sélection des éléments en fonction de l'état des autres. Premièrement, ils ne peuvent pas accéder directement à l’état des éléments à l’aide d’un sélecteur parent ou d’un sélecteur frère précédent. Deuxièmement, ils ne peuvent cibler qu'un seul élément comme sujet du sélecteur, ce qui nous empêche d'appliquer des styles à plusieurs éléments en fonction d'une condition.

Exemple : Ciblage d'éléments en fonction de l'état de survol

Disons que nous avons plusieurs sections sur une page. Chaque section contient un div avec un attribut de données « terminé » représentant son statut. Nous souhaitons ajouter une bordure colorée aux éléments clignotants et en rotation dans la section suivante chaque fois que le div avec l'attribut "terminé" est survolé. Un sélecteur CSS simple pour cela serait :

section:hover + section .blink,
section:hover + section .spin {
  border: 1px solid red;
}

Cependant, cela ne fonctionne pas car CSS n'a pas de sélecteur parent pour cibler le div dans la première section.

Solution potentielle : Selectors 4 et :has()

Le prochain brouillon de Selectors 4 introduit une pseudo-classe appelée :has() qui résout ce problème. :has() nous permet de sélectionner des éléments qui ont un descendant spécifique. Il prend un argument de sélection relatif qui correspond aux descendants de l'élément sur lequel il est utilisé.

Une solution utilisant :has() pour le problème ci-dessus serait :

section:has(div[data-status~=finished]) + section div:matches(.blink, .spin) {
  border: 1px solid red;
}

Ici, : has() garantit que le sélecteur cible uniquement les sections contenant un div avec le statut « terminé ». Il combine également le combinateur enfant avec :matches() pour cibler à la fois les éléments clignotants et tournants dans la section suivante.

Conclusion

Bien que les sélecteurs CSS actuels aient des limites dans la sélection éléments basés sur l'état des autres, la prochaine pseudo-classe :has() dans Selectors 4 fournit une solution potentielle. Il améliore la syntaxe du sélecteur, permettant plus de flexibilité et un ciblage conditionnel des éléments.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiquesDemystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiquesMar 08, 2025 am 09:45 AM

Ceci est le 3ème article d'une petite série que nous avons faite sur l'accessibilité. Si vous avez manqué le deuxième article, consultez "Gestion de la mise au point des utilisateurs avec: Focus-visible". Dans

Créez un formulaire de contact JavaScript avec le cadre Smart FormsCréez un formulaire de contact JavaScript avec le cadre Smart FormsMar 07, 2025 am 11:33 AM

Ce tutoriel montre la création de formulaires JavaScript professionnels à l'aide du cadre Smart Forms (Remarque: non plus disponible). Bien que le cadre lui-même ne soit pas disponible, les principes et techniques restent pertinents pour d'autres constructeurs de formulaires.

Ajout d'ombres de boîte aux blocs et éléments WordPressAjout d'ombres de boîte aux blocs et éléments WordPressMar 09, 2025 pm 12:53 PM

Le CSS Box-Shadow et les propriétés de contour ont gagné le thème. Laissez regarder quelques exemples de la façon dont cela fonctionne dans des thèmes réels et des options que nous devons appliquer ces styles aux blocs et éléments WordPress.

Travailler avec GraphQL CachingTravailler avec GraphQL CachingMar 19, 2025 am 09:36 AM

Si vous avez récemment commencé à travailler avec GraphQL ou examiné ses avantages et ses inconvénients, vous avez sans aucun doute entendu des choses comme "GraphQL ne prend pas en charge la mise en cache" ou

Faire votre première transition Svelte personnaliséeFaire votre première transition Svelte personnaliséeMar 15, 2025 am 11:08 AM

L'API de transition Svelte fournit un moyen d'animer les composants lorsqu'ils entrent ou quittent le document, y compris les transitions Svelte personnalisées.

Show, ne dit pasShow, ne dit pasMar 16, 2025 am 11:49 AM

Combien de temps passez-vous à concevoir la présentation de contenu pour vos sites Web? Lorsque vous écrivez un nouveau blog ou créez une nouvelle page, pensez-vous à

Barbars CSS personnalisés chics et cool: une vitrineBarbars CSS personnalisés chics et cool: une vitrineMar 10, 2025 am 11:37 AM

Dans cet article, nous plongerons dans le monde des barres de défilement. Je sais, ça ne semble pas trop glamour, mais croyez-moi, une page bien conçue va de pair

Que diable sont les commandes NPM?Que diable sont les commandes NPM?Mar 15, 2025 am 11:36 AM

Les commandes NPM exécutent diverses tâches pour vous, soit en tant que processus unique ou en cours d'exécution pour des choses comme le démarrage d'un serveur ou la compilation de code.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Musée à deux points: toutes les expositions et où les trouver
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser