Perfekt vernetzte Website

Teil 6: [Workshop] Bessere Web-Site mit CSS - Usability verbessern

Noch erinnert nicht viel an ein Menü. Die untereinander platzierten Punkte sehen immer noch wie eine Liste aus. Deswegen fügen wir im nächsten Schritt einen Rahmen um die einzelnen Punkte hinzu:

ul li a { display: block;
text-decoration: none;background: white; padding: 5px;border: 1px solid black;border-bottom: 0; }

Die Darstellung erfolgt im Block, sodass die Elemente weiterhin untereinander erscheinen. Es gibt einen Innenabstand von fünf Pixeln, sodass auch der Text nicht direkt am Rahmen anklebt.

Wenn Sie Ihr zukünftiges Menü im Internet Explorer aufrufen, sehen Sie, dass die Rahmen der einzelnen Menüpunkte nicht wie erwartet direkt aneinander anschließen, sondern eine Lücke zwischen Ihnen besteht. Diese schließen Sie einfach mit folgendem IE-Hack:

/* Fix IE. \*/
* html ul li {
float: left; }
* html ul li a {
height: 1%; }

Nun fehlt nur noch der Abschluss nach unten, denn an dieser Stelle ist das Menü immer noch offen. Überarbeiten Sie dazu Ihre Definition von ul und fügen Sie dieser die Zeile hinzu:

border-bottom: 1px solid black;

Abschließend müssen Sie nur noch die Untermenüs zum Leben erwecken. Nutzen Sie dazu die Pseudo-Klasse :hover.

li:hover ul { display: block; }

Aktuelle Browser, welche CSS richtig interpretieren, zeigen Ihnen nun das Hauptmenü und falls vorhanden das passende Untermenü an. Für den Internet Explorer müssen Sie nun noch einen Workaround schaffen, damit auch dieser die Untermenüs darstellen kann. Sie setzen dafür zwar Javascript ein, aber keine Sorge. Die Crawler erkennen die Verlinkungen trotzdem, da unsere Basis ja eine verschachtelte Liste ist.

© Archiv

Damit auch der Internet Explorer die zweite Hierarchiestufe darstellen kann, müssen Sie mit ein wenig Javascript nachhelfen.

Anpassung auf IE

Damit der Internet Explorer auch die Untermenüs aufklappt, benötigen Sie als Erstes eine Klassenzuweisung für Ihre komplette Liste.

<ul id="navi">

Mit dieser wird anschließend die Verarbeitung über das window.onload- Ereignis abgefangen. Dieses ruft die Funktion menu_ausklappen auf.

Für alle Elemente Ihrer Liste navi wird nun untersucht, ob es sich um einen Aufzählungspunkt handelt. Diese werden über den Namen LI erkannt. Wird die Maus über eines dieser Listenelemente bewegt, reagiert das Skript auf das Ereignis onmouseover und weist dem Element den Klassennamen over zu. Für diesen wird innerhalb der CSS-Definition die gleiche Verfahrensweise wie für das :hover-Ereignis definiert:

li:hover ul, li.over ul { display:
block; }

Abschließend wird, wenn das onmouseout-Ereignis zum Tragen kommt, die Klassenzuweisung wieder entfernt und so das Untermenü auch wieder eingeklappt.

menu_ausklappen = function() {
if (document.all&&document.getEle
mentById) {
wurzel_menu = document.
getElementById("navi");
for (i=0; i<wurzel_menu.childNodes.
length; i++) {
knoten = wurzel_menu.childNodes[i];
if (knoten.nodeName=="LI") {
knoten.onmouseover=function() {
this.className+=" over";
}
knoten.onmouseout=function() {
this.className=this.className.
replace(" over", "");
}
}
}
}
}

Damit reagiert auch der Internet Explorer auf die Mausbewegung und Sie können ohne weitere Einschränkungen Ihre Menüs aufbauen und sicherstellen, dass die internen Verlinkungen trotz Javascript auch von den Crawlern erkannt werden.

Mehr lesen

Chronologische Liste und Netflix-Links -

Neuerscheinungen in der Übersicht -

Vorschau auf Film- und Serien-Highlights -

Mehr zum Thema

Webdesign

Adobe Illustrator wird im Webdesign immer beliebter. Wie Sie das Tool richtig einsetzen, erfahren Sie hier.
Facebook

Was sind die Implikationen für Unternehmen und Endanwender bei Facebooks neuer Suche Graph Search?
Online-Recht

Allgemeine Geschäftsbedingungen liest sich niemand gerne durch. Sie sind jedoch notwendig und äußerst sinnvoll. Worauf sie achten sollten.
Online-Recht in der Cloud

Dateien werden immer häufiger in der Cloud bereitgestellt. Rechtlich ist das jedoch durchaus problematisch. Wir klären über das Urheberrecht in der…
E-Commerce-Logistik

Für den Erfolg eines Online-Shops sind zahlreiche Faktoren verantwortlich. Neben Produktvielfalt und Darstellung der Waren gehört auch die Logistik.