views:

2557

answers:

4

This page does it the way I want it to: http://www.web-source.net/javascript_redirect_box.htm

But I want to find a better way using jQuery, can anyone point me to a good script that uses jQuery to accomplish this?

+1  A: 

I haven't tested this but I think it's equivalent to the sample on the page you referenced.

$(document).ready( function() {
   $('#select').change( function() {
      location.href = $(this).val();
   }
});

<select id="select">
    <option value="#">Select a location</option>
    <option value="location.htm">Location</option>
    <option value="other.htm">Other</option>
</select>
tvanfosson
+6  A: 

You don't need a pre-packaged script for this, just a couple lines of code.

// get your select element and listen for a change event on it
$('#selectEl').change(function() {
  // set the window's location property to the value of the option the user has selected
  window.location = $(this).val();
});
Sasha Sklar
+6  A: 

Others have given good answers on how to do this, but...

Just a warning, IE handles select list onChange very differently from other browsers when someone is navigating via a keyboard. It counts every key up/key down press as an onChange event, meaning that you can't navigate a redirect select list via keyboard, killing accessibility for users who can't use the mouse. (Other browsers wait for an "enter" event, or a tab out of the select list, before firing onChange.) I've spent a long, long time trying to hack a workaround for this, and never fully solved the problem.

I don't know if jQuery accounts for this; hopefully it does, for your site's accessibility's sake.

It may be worth making the select list choose where to go, then have a button next to it actually activate the redirect. (Unless you don't care about IE users' accessibility.)

Daniel Lew
If this issue is particularly important to you, check this out: http://www.themaninblue.com/writing/perspective/2004/10/19/ - it has a cross-browser implementation that handles this for IE.
Paolo Bergantino
Unfortunately, that code doesn't handle a user who might use both the keyboard and the mouse. For example, mouse wheels put a huge dent into the whole problem, because each item wheeled by fires another onChange.
Daniel Lew
Ah. Touche. I'm kind of intrigued by this so I'll try to see if I can find anything.
Paolo Bergantino
+1, everyone gets this wrong and then acts surprised when laptop keyboard users complain. It's surprisingly tricky to get this ‘right’ across all the keypress, change and blur events.
bobince
+2  A: 

Simple answer, as Daniel suggests, is - you shouldn't do this, it's bad for usability and accessibility.

Select list behaviour is dependent on a combination of the user's OS, Browser and user settings (for both). Add to that the fact that the onchange event isn't implemented in a standard way across browsers.

Users should be able to have expected behaviour from a select list regardless of whether they use mouse, keyboard or mousewheel or (voice, screenreader, whatever...). If you do bind an event to the onchange it should never be one which takes the user's focus away from the select list eg. page redirect.

(Personally I navigate site forms a lot using keyboard, and if this happens I scream)

mdja