CSS-Auswahl, die für Elemente mit zwei Klassen gilt


472

Gibt es eine Möglichkeit, ein Element mit CSS basierend auf dem Wert des Klassenattributs auszuwählen, das auf zwei bestimmte Klassen festgelegt wird? Nehmen wir zum Beispiel an, ich habe 3 Divs:

<div class="foo">Hello Foo</div>
<div class="foo bar">Hello World</div>
<div class="bar">Hello Bar</div>

Welches CSS könnte ich schreiben, um NUR das zweite Element in der Liste auszuwählen, basierend auf der Tatsache, dass es Mitglied der Klassen foo UND bar ist?

Antworten:


735

Verketten Sie beide Klassenselektoren (ohne Leerzeichen dazwischen):

.foo.bar {
    /* Styles for element(s) with foo AND bar classes */
}

Wenn Sie immer noch mit alten Browsern wie IE6 arbeiten müssen, beachten Sie, dass verkettete Klassenselektoren nicht korrekt gelesen werden: Stattdessen wird nur der letzte Klassenselektor ( .barin diesem Fall) gelesen , unabhängig davon, welche anderen Klassen Sie auflisten.

Betrachten Sie dieses CSS, um zu veranschaulichen, wie andere Browser und IE6 dies interpretieren:

* {
    color: black;
}

.foo.bar {
    color: red;
}

Die Ausgabe in unterstützten Browsern ist:

<div class="foo">Hello Foo</div>       <!-- Not selected, black text [1] -->
<div class="foo bar">Hello World</div> <!-- Selected, red text [2] -->
<div class="bar">Hello Bar</div>       <!-- Not selected, black text [3] -->

Ausgabe auf IE6 ist:

<div class="foo">Hello Foo</div>       <!-- Not selected, black text [1] -->
<div class="foo bar">Hello World</div> <!-- Selected, red text [2] -->
<div class="bar">Hello Bar</div>       <!-- Selected, red text [2] -->

Fußnoten:

  • Unterstützte Browser:
    1. Nicht ausgewählt, da dieses Element nur eine Klasse hat foo.
    2. Ausgewählte als dieses Element hat beiden Klassen foound bar.
    3. Nicht ausgewählt, da dieses Element nur eine Klasse hat bar.

  • IE6:
    1. Nicht ausgewählt, da dieses Element keine Klasse hat bar.
    2. Ausgewählt, da dieses Element eine Klasse hat bar, unabhängig von anderen aufgelisteten Klassen.

3
Ist es wichtig, in welcher Reihenfolge ich sie eingebe?
Adam

3
Es spielt keine Rolle. (Es wird für IE6 aufgrund seiner Interpretation, vorausgesetzt, Sie müssen es unterstützen.)
BoltClock

6
Ist es wichtig, dass zwischen ihnen kein Platz ist?
CodyBugstein

26
@Imray: Ja, das Leerzeichen stellt einen Nachkommen-Selektor dar, wodurch jeder Klassen-Selektor ein anderes Element darstellt. Aber wir sprechen hier von einem einzigen Element.
BoltClock

2
@ David Brossard: Ja, das tut es.
BoltClock
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.