CSS, HTML und Javascript mit {stil}

Javascript classList

CSS Klassen hinzufügen, entfernen und toggle class

classList fügt einem Element CSS-Klassen mit add, remove, toggle so einfach wie mit jQuery addClass, removeClass und toggleClass hinzu und entfernt sie ebenso einfach wieder. classlist.contains testet, ob ein Element eine Klasse enthält.

Vor HTML5 war das class-Attribut eine Qual für Javascript. Wir können zwar beliebig viele Klassen in einem class-Attribut unterbringen, aber der Zugriff auf class war mit der heißen Nadel gestrickt und ging immer davon aus, dass es nur einen Wert für das class-Attribut gibt.

Die DOM4-Spezifikation verliert gerade mal einen Satz zu classList. Ich habe das Gefühl, das W3C schämt sich, dass classList erst 10 Years After dabei ist.

classList

Wenn jQuery sowieso geladen wird, ist classList kein Thema, aber für triviale Manipulationen erspart classList das Einbinden von jQuery.

Wenn classList dennoch eingesetzt wird, hilft ein Polyfill: eligray classList.js.

  • classList.add()

    fügt der classList eine neue Klasse hinzu

  • classList.remove()

    entfernt eine Klasse aus der classList, ohne die übrigen Klassen zu beeinflussen.

  • classList.contains()

    prüft, ob eine Klasse in der classList liegt

  • classList.toggle()

    toggelt eine Klasse in die classList bzw. hinaus. Beim ersten Aufruf wird die Klasse eingeschaltet, beim zweiten Aufruf wird die Klasse entfernt.

  • classList.item()

    gibt die Klasse an der angegebenen Position innerhalb der Liste zurück

  • classList.toString()

    wandelt die Liste in einen String um

  • classList.length

    gibt die Zahl der Klassen in der classList an

  • classList.value

    fügt dem classList-Objekt eigene Eigenschaft und Methoden hinzu

classList toggle

classList.toggle() ist wie geschaffen für das »slidedown« und »slideup« in den responsiven Menüs der mobilen Geräte.

Das Beispiel nutzt CSS transition für den slide-Effekt.

  • classList.add()
  • classList.contains()
  • classList.item()
  • classList.length
  • classList.remove()
  • classList.toggle
.toggle { 
    transition: height 1s ease-in-out; 
    height: 0px; overflow:hidden;
}
.slowdown { height: 160px }

Das Icon ist eine SVG-Grafik, class toggle ist eine HTML-Liste

<div class="icon">
    <svg  width="100" height="60" viewBox="0 0 600 240">…</svg>
</div>

<ul class="toggle">
    <li>classList.add()</li>
    <li>classList.contains()</li>
	…
</ul>

Zum Toggeln mit Javascript classList reichen ein paar Zeilen Code:

Toggeln mit Javascript classList
<script>
var icon = document.querySelector('.icon');
icon.addEventListener('click', function () {
    document.querySelector('.toggle').classList.toggle('slowdown');
});
</script>

elem.classList.contains

jQuery hat die wunderbare Methode hasClass. Mit purem Javascript (Vanilla) war der Test, ob ein Element eine bestimmte Klasse aufweist, immer Würfeln ohne Sechser.

contains() gibt true oder false zurück, je nachdem, ob die Klasse in der Liste der Klassen des Elements enthalten ist oder nicht.

<img id="elem" class="bird1 bird2 bird3" … />
…
if (elem.classList.contains('bird1')) {
}

classList.item

elem.classList.item() gibt den Namen der Klasse an einer Position zurück. classList.item() ist kein Array, also keine eckigen Klammern!


Mehrere Klassen

In jQuery fügt $(elem).addClass("first second third") einem Element gleich mehrere Klassen hinzu; mit classList ist die Syntax ähnlich, aber die einzelnen Klassen müssen in Hochkommas und von Kommas getrennt geschrieben werden.

Javascript classList mehrere Klassen

Der Aufruf

console.log (document.querySelector('#b2').classList);

liefert

DOMTokenList 0: "bird1" 1: "bird2" 2: "bird3" constructor: DOMTokenListConstructor length: 3

classList vs className

className setzt und liest den Namen der Klassen eines Elements, aber className liefer die Namen der Klassen in einem String, getrennt durch Leerzeichen. Damit kann man arbeiten, aber nicht so komfortabel wie mit classList.

<div id="look" class="foo bar nos">
…
</div>

console.log (look.className) zeigt



	

Eine Klasse mit className hinzufügen:

look.className = look.className + " more";

Testen, ob look die Klasse bar enthält:

if (/bar/.test(look.className) === true) console.log ("contains");

oder auf classname testen mit search

var result = classes.search("bar");

Gibt "4" zurück, weil 4 der Startindex von bar im className-String ist.

Browser-Unterstützung für classList

classList wird von allen modernen Browser unterstützt (Internet Explorer ab Version 10).

Internet Explorer unterstützt classList erst ab Version 10, aber es gibt ein Polyfil für classList bei github

{ } { } { }