Aaron Gustafson is putting together a series of articles on how to make select elements stylable. In essence, what his work does is take the select out of the DOM and replace it with a ul, and then add script and CSS to make that ul work like a dropdown list. The advantage this gives is clear to everyone who’s ever complained about how selects aren’t stylable! The series has only just started, and there are a few concerns — the new element can’t be tabbed to, and doesn’t respond to keyboard events — but Aaron promises that part 2 will cover accessibility issues.

The script uses similar techniques to the Suckerfish dropdowns, applying “hover” and “selected” classes to various parts of the ul to provide hooks for styling (since IE doesn’t support :hover on things that aren’t links). This should be a useful technique to watch!

  • Thanks for the heads up Stuart, I wonder what browsers it’ll be compatible with *wonders off to read*

  • He didn’t add a document.onclick=”hide the menu”, so if you click the drop down and then click somewhere else, it doesn’t disappear. Other than that, cool.

  • Ick! It doesn’t even work in Opera. I hate Firefox only coders…

  • Andy

    Works fine here in Opera (7.51), Firefox and IE.

  • Would be nice if it layered over the top of the form rather than taking up space in the page flow when its expanded.

  • schallm

    Looks great, but I would agree with mrsmiley. Also, keyboard support is a must. Should be able to tab to the control and select with keyboard.

  • Very stylish! :D Would be nice to read about the accessibility issues.

  • Interesting, I published a similar piece some time ago:

  • Your article is very informative and helped me further.

    Thanks, David

Get the latest in JavaScript, once a week, for free.