Abo
  • Services:
Anzeige
Bessere Dropdown-Menüs fürs Web
Bessere Dropdown-Menüs fürs Web (Bild: Ben Kamens)

Vorbild Amazon: Dropdown-Menüs fürs Web, wie sie sein sollten

Aufklappende Untermenüs in Webseiten sind oft langsam oder verlangen eine sehr präzise Mausführung. Ben Kamens hat eine clevere Idee von Amazon aufgegriffen und ein jQuery-Plugin daraus gemacht, um das zu ändern.

Ben Kamen, Chefentwickler der Khan Academy, hat mit jQuery-menu-aim ein jQuery-Plugin für Dropdown-Menüs mit Untermenüs entwickelt, das unterscheiden kann, ob ein Nutzer den nächsten Kategoriepunkt oder einen Link im danebenliegenden Untermenü ansteuern will. Auf die Idee brachte ihn Amazon, dessen großes Kategorie-Menü besser funktioniert als die meisten Dropdown-Menüs im Web.

Anzeige

Das Problem: Je nachdem, über welchem Menüpunkt gerade der Mauszeiger ist, wird daneben ein anderes Untermenü angezeigt, das seinerseits mehrere Punkte enthält. Will der Nutzer nun einen dieser Menüpunkte aufrufen und nimmt mit der Maus den direkten Weg, berührt der Mauszeiger oft zwischendurch eine andere Kategorie und das Untermenü ändert sich. Der Nutzer ist also gezwungen, den Mauszeiger horizontal ins Untermenü zu bewegen und dann vertikal zum gewünschten Menüpunkt.

Eine Möglichkeit, dieses Problem zu umgehen, besteht darin, zwischen den Untermenüs nur mit einer Zeitverzögerung umzuschalten. Fährt der Nutzer dann versehentlich über eine andere Kategorie, erreicht aber vor Ablauf der gegeben Zeit das jeweilige Untermenü, wird die Kategorie und damit auch das Untermenü nicht gewechselt.

In welche Richtung bewegt sich die Maus?

Eine solche Zeitverzögerung vereinfacht es zwar deutlich, einzelne Punkte im Untermenü anzusteuern, macht das gesamte Dropdown-Menü aber langsam.

Amazon macht das in seinem Kategorien-Menü besser: Hier wird schnell umgeschaltet, wenn der Nutzer mit der Maus vertikal über die Kategorien fährt. Steuert er aber einen Punkt in dem danebenliegenden Untermenü an, wechselt die Kategorie nicht, auch wenn der Mauszeiger zwischendurch über eine andere Kategorie fährt.

Dieses Verhalten hat Kamens so fasziniert, dass er sich die Funktionsweise von Amazons Menü genauer angesehen und letztendlich übernommen hat: Amazon und so auch Kamens jQuery-Plugin erkennen, in welche Richtung die Maus bewegt wird. Findet die Bewegung im Dreieck zwischen dem Ausgangspunkt des Mauszeigers und der rechten oberen und rechten unteren Ecke des Hauptmenüs statt, wird nur verzögert umgeschaltet, da der Nutzer vermutlich einen Punkt im Untermenü ansteuert. Bei Bewegungen außerhalb dieses Dreiecks wird sofort reagiert.

So entsteht ein Menü, das sehr schnell reagiert, aber einfach zu benutzen ist. Kamens nutzt es im "Lern-Menü" der Khan-Academy-Website. Das dafür entwickelte jQuery Plugin "jQuery-menu-aim" hat Kames auf Github als Open Source unter der MIT-Lizenz veröffentlicht.


eye home zur Startseite
redmord 11. Mär 2013

Ja, man muss auch immer sehen wie die strukturelle Trennung sinnvoll ist. Natürlich kann...

redmord 09. Mär 2013

Einige Funktionen werden sehr häufig benutzt. Im Grunde ist es ja auch nur eine Sammlung...

RcRaCk2k 08. Mär 2013

Genial, dass es solch einen Beitrag gibt und man darüber diskutiert ;) Für mich ist das...

meshuggah 08. Mär 2013

Also mir war es nicht bewusst / kannte es nicht, daher habe ich es mir bei Amazon mal...

cry88 08. Mär 2013

mit chrome geht das relativ gut, man muss halt gedrückt halten damit das kontextmenü...


Technologie4web / 03. Apr 2013



Anzeige

Stellenmarkt
  1. Vodafone Kabel Deutschland GmbH, Berlin
  2. T-Systems International GmbH, Bonn, Berlin
  3. Allianz Deutschland AG, Unterföhring
  4. Zurich Gruppe Deutschland, Bonn


Anzeige
Hardware-Angebote
  1. ab 189,00€ im PCGH-Preisvergleich
  2. bei Alternate

Folgen Sie uns
       


  1. Fujifilm

    Neue Sensoren und besserer Autofokus für X-Kameras

  2. Streaming

    Netflix zeigt Rekordwachstum

  3. Messsucherkamera

    Leica M10 schrumpft trotz Vollformatsensor

  4. Halo Wars 2 angespielt

    Mit dem Warthog an die Strategiespielfront

  5. Hoverbike

    US-Armee fliegt wie Luke Skywalker

  6. Gulp-Umfrage

    Welche Kenntnisse IT-Freiberufler brauchen

  7. HPE

    650 Millionen Dollar für den Einstieg in die Hyperkonvergenz

  8. Begnadigung

    Danke, Chelsea Manning!

  9. Android 7

    Nougat für Smartphones von Sony, Oneplus, LG und Huawei

  10. Simplygon

    Microsoft reduziert 3D-Details



Haben wir etwas übersehen?

E-Mail an news@golem.de


Anzeige
Intel Core i7-7700K im Test: Kaby Lake = Skylake + HEVC + Overclocking
Intel Core i7-7700K im Test
Kaby Lake = Skylake + HEVC + Overclocking
  1. Kaby Lake Intel macht den Pentium dank HT fast zum Core i3
  2. Kaby Lake Refresh Intel plant weitere 14-nm-CPU-Generation
  3. Intel Kaby Lake Vor der Vorstellung schon im Handel

Dienste, Programme und Unternehmen: Was 2016 eingestellt und geschlossen wurde
Dienste, Programme und Unternehmen
Was 2016 eingestellt und geschlossen wurde
  1. Kabel Mietminderung wegen defektem Internetkabel zulässig
  2. Grundversorgung Kanada macht Drosselung illegal
  3. Internetzugänge 50 MBit/s günstiger als 16 MBit/s

GPD Win im Test: Crysis in der Hosentasche
GPD Win im Test
Crysis in der Hosentasche
  1. FTC Qualcomm soll Apple zu Exklusivvertrag gezwungen haben
  2. Steadicam Volt Steadicam-Halterung für die Hosentasche
  3. Tastaturhülle Canopy hält Magic Keyboard und iPad zum Arbeiten zusammen

  1. Re: lg gibt Diät via Update?

    kaymvoit | 09:51

  2. Re: Das ist traurig

    My1 | 09:50

  3. Re: Begnadigung, bei positiver Wertung vieler...

    theonlyone | 09:50

  4. Re: Ein Film im Half-Life Universum?

    SlightlyHomosex... | 09:49

  5. Re: Auflösung nebensächlich, hauptsache kein...

    My1 | 09:49


  1. 09:35

  2. 09:08

  3. 09:04

  4. 09:01

  5. 08:46

  6. 19:06

  7. 17:37

  8. 17:23


  1. Themen
  2. A
  3. B
  4. C
  5. D
  6. E
  7. F
  8. G
  9. H
  10. I
  11. J
  12. K
  13. L
  14. M
  15. N
  16. O
  17. P
  18. Q
  19. R
  20. S
  21. T
  22. U
  23. V
  24. W
  25. X
  26. Y
  27. Z
  28. #
 
    •  / 
    Zum Artikel