suchen
HeimWeb-FrontendCSS-TutorialKönnen CSS-Selektoren auf Elemente basierend auf dem Status anderer Elemente abzielen?

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

So wählen Sie Elemente basierend auf dem Zustand anderer Elemente mit CSS aus

Einführung

Die Ausrichtung auf bestimmte Elemente war schon immer ein grundlegender Aspekt von CSS. Allerdings entstehen Komplexitäten, wenn wir Elemente basierend auf dem Status anderer Elemente auf der Seite formatieren müssen. In diesem Artikel werden die Einschränkungen aktueller CSS-Selektoren untersucht und eine mögliche Lösung aus einem kommenden Standard vorgestellt.

Einschränkungen aktueller CSS-Selektoren

CSS-Selektoren haben mehrere Einschränkungen bei der Auswahl von Elementen basierend auf dem Zustand anderer. Erstens können sie nicht direkt auf den Status von Elementen zugreifen, indem sie einen übergeordneten Selektor oder einen vorherigen Geschwisterselektor verwenden. Zweitens können sie nur auf ein einzelnes Element als Betreff des Selektors abzielen, was uns daran hindert, Stile basierend auf einer Bedingung auf mehrere Elemente anzuwenden.

Beispiel: Auf Elemente basierend auf dem Hover-Status abzielen

Nehmen wir an, wir haben mehrere Abschnitte auf einer Seite. Jeder Abschnitt enthält ein Div mit einem „fertigen“ Datenattribut, das seinen Status darstellt. Wir möchten den blinkenden und sich drehenden Elementen im nächsten Abschnitt einen farbigen Rahmen hinzufügen, wenn der Mauszeiger über das Div mit dem Attribut „fertig“ bewegt wird. Ein einfacher CSS-Selektor hierfür wäre:

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

Dies funktioniert jedoch nicht, da CSS keinen übergeordneten Selektor hat, um auf das Div im ersten Abschnitt abzuzielen.

Mögliche Lösung: Selectors 4 und :has()

Der kommende Selectors 4-Entwurf führt eine Pseudoklasse namens ein :has() was dieses Problem löst. :has() ermöglicht es uns, Elemente auszuwählen, die einen bestimmten Nachkommen haben. Es benötigt ein relatives Selektorargument, das Nachkommen des Elements übereinstimmt, für das es verwendet wird.

Eine Lösung mit :has() für das obige Problem wäre:

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

Hier: has() stellt sicher, dass der Selektor nur auf Abschnitte abzielt, die ein Div mit dem Status „fertig“ enthalten. Außerdem wird der untergeordnete Kombinator mit :matches() kombiniert, um sowohl auf blinkende als auch sich drehende Elemente im folgenden Abschnitt abzuzielen.

Fazit

Während aktuelle CSS-Selektoren Einschränkungen bei der Auswahl haben Elemente basierend auf dem Zustand anderer Elemente zu analysieren, bietet die kommende Pseudoklasse :has() in Selectors 4 eine mögliche Lösung. Es verbessert die Selektorsyntax und ermöglicht so mehr Flexibilität und bedingtes Targeting von Elementen.

Das obige ist der detaillierte Inhalt vonKönnen CSS-Selektoren auf Elemente basierend auf dem Status anderer Elemente abzielen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Wie wir Google -Schriftarten getaggt und Goofonts.com erstellt habenWie wir Google -Schriftarten getaggt und Goofonts.com erstellt habenApr 12, 2025 pm 12:02 PM

Goofonts ist ein Nebenprojekt, das von einer Entwicklerin und einem Designer-Ehemann signiert wurde, beide große Fans der Typografie. Wir haben Google markiert

Zeitlose Web -EntwicklerartikelZeitlose Web -EntwicklerartikelApr 12, 2025 am 11:44 AM

Pavithra Kodmad bat die Menschen um Empfehlungen zu den Angaben, die sie für einige der zeitlossten Artikel über Webentwicklung hielten, die ihre verändert haben

Der Deal mit dem AbschnittselementDer Deal mit dem AbschnittselementApr 12, 2025 am 11:39 AM

Zwei Artikel veröffentlichten genau den selben Tag:

Üben Sie GraphQL -Abfragen mit dem Status der JavaScript -APIÜben Sie GraphQL -Abfragen mit dem Status der JavaScript -APIApr 12, 2025 am 11:33 AM

Das Erstellen des Erstellens von GraphQL -APIs kann eine große Herausforderung sein. Sie können jedoch lernen, wie Sie GraphQL -APIs in 10 Minuten verwenden! Und es passiert so, dass ich das perfekte bekommen habe

CMSS auf KomponentenebeneCMSS auf KomponentenebeneApr 12, 2025 am 11:09 AM

Wenn eine Komponente in einer Umgebung lebt, in der die Datenabfragen sie in der Nähe leben, gibt es eine ziemlich direkte Grenze zwischen der visuellen Komponente und der

Geben Sie den Typ auf einen Kreis ein ... mit Offset-PfadGeben Sie den Typ auf einen Kreis ein ... mit Offset-PfadApr 12, 2025 am 11:00 AM

Hier ist einige legitime CSS -Tricks von Yuanchuan. Es gibt diesen CSS-Immobilien-Offset-Pfad. Es war einmal, es wurde als Bewegungspfad bezeichnet und dann umbenannt. ICH

Was macht 'Rückkehr' in CSS?Was macht 'Rückkehr' in CSS?Apr 12, 2025 am 10:59 AM

Miriam Suzanne erklärt in einem Mozilla -Entwickler -Video zu diesem Thema.

Die modernen LiebhaberDie modernen LiebhaberApr 12, 2025 am 10:58 AM

Ich liebe solche Sachen.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.