ChatGPT解决这个技术问题 Extra ChatGPT

How do you select a particular option in a SELECT element in jQuery?

If you know the Index, Value or Text. also if you don't have an ID for a direct reference.

This, this and this are all helpful answers.

Example markup

<div class="selDiv">
  <select class="opts">
    <option selected value="DEFAULT">Default</option>
    <option value="SEL1">Selection 1</option>
    <option value="SEL2">Selection 2</option>
  </select>
</div>
$("#my_select").val("the_new_value").change(); ... ... from so

N
Nante

A selector to get the middle option-element by value is

$('.selDiv option[value="SEL1"]')

For an index:

$('.selDiv option:eq(1)')

For a known text:

$('.selDiv option:contains("Selection 1")')

EDIT: As commented above the OP might have been after changing the selected item of the dropdown. In version 1.6 and higher the prop() method is recommended:

$('.selDiv option:eq(1)').prop('selected', true)

In older versions:

$('.selDiv option:eq(1)').attr('selected', 'selected')

EDIT2: after Ryan's comment. A match on "Selection 10" might be unwanted. I found no selector to match the full text, but a filter works:

 $('.selDiv option')
    .filter(function(i, e) { return $(e).text() == "Selection 1"})

EDIT3: Use caution with $(e).text() as it can contain a newline making the comparison fail. This happens when the options are implicitly closed (no </option> tag):

<select ...>
<option value="1">Selection 1
<option value="2">Selection 2
   :
</select>

If you simply use e.text any extra whitespace like the trailing newline will be removed, making the comparison more robust.


:contains is not great as it will match pieces of text; problematic if any of your option text is a substring of another option text.
This is works too $('#id option[value="0"]').attr('selected', 'selected');
@Grastveit how to change the color of first option if it is selected or not when it has a class say myClass. Thanks
I'd like to add you should DEFINITELY use prop and not attr. I almost went nuts trying to debug an application and changing from attr to prop fixed it.
Now that :eq(#) is deprecated (api.jquery.com/category/deprecated/deprecated-3.4), the :eq(#) choice should be avoided. It still works for now, but supposedly will break with jQuery 4.0.
A
Andrew Whitaker

None of the methods above provided the solution I needed so I figured I would provide what worked for me.

$('#element option[value="no"]').attr("selected", "selected");

Note as of jQuery 1.6 this should use prop and not attr.
@GoneCoding Using .attr is correct. "selected" is an attribute of the <option> w3.org/TR/html5/forms.html#attr-option-selected
@CarlosLlongo: That is irrelevant. The jQuery recommendation is to always use prop in preference to attr. That saves having to look up each and every property on w3.org in order to see if it is only an attribute, or implemented with backing actions.
L
Leandro Ardissone

You can just use val() method:

$('select').val('the_value');

This is wrong because you are SETTING the value of ALL the SELECT elements to the_value. .val is not selector/filter function! It is a property accessor and passing it that string SETS the value. I tried to take my upvote back but was too late after I reallized this in testing.
Please @AaronLS and @guilhermeGeek, refer to the docs (last example). It works as a selector for select, checkboxes and radio buttons, and as a value setter for text inputs and textareas.
You have misread the documentation. For checkboxes, radios, and listboxes the command sets the "selected" attribute for those items. The last example shows how passing val("checkbox 1") causes it to become selected. This is not the same as a "selector" in terms of getting the objects via CSS/jquery selector. I tested your code, it doesn't work bottom line.
+1: no, it's not a JQuery selector, however I think most people searching for this question are like me, and simply want to change the currently selected option; coming up with an actual selector is merely a way to do that. And this is certainly better than answers that I've seen that have you iterate over all of the options.
@theUtherSide: I would not always go by a consensus. The val() setter on a select is implemented by setting the selected property of a child option where the value matches, so is really does do what the question wanted (but only for value searches and not text searches).
P
Pbk1303

By value, what worked for me with jQuery 1.7 was the below code, try this:

$('#id option[value=theOptionValue]').prop('selected', 'selected').change();

I'm not sure you need the .change() method.
The .change() was necessary. I had an example where I was switching thumbnails based on a SELECT. When I uploaded a custom theme, it was supposed to select "Custom Theme" from the list of options. The .prop() call worked, but without the .change(), the thumbnail image on the right of my select never updated.
.change() was the best advise. +1
Note: a boolean prop value generates the same output. e.g. .prop('selected', true)
Depends, some browsers - maybe old browsers - need of the string 'selected'. I think the majority of them support the text string.
G
Gone Coding

There are a number of ways to do this, but the cleanest approach has been lost among the top answers and loads of arguments over val(). Also some methods changed as of jQuery 1.6, so this needs an update.

For the following examples I will assume the variable $select is a jQuery object pointing at the desired <select> tag, e.g. via the following:

var $select = $('.selDiv .opts');

Note 1 - use val() for value matches:

For value matching, using val() is far simpler than using an attribute selector: https://jsfiddle.net/yz7tu49b/6/

$select.val("SEL2");

The setter version of .val() is implemented on select tags by setting the selected property of a matching option with the same value, so works just fine on all modern browsers.

Note 2 - use prop('selected', true):

If you want to set the selected state of an option directly, you can use prop (not attr) with a boolean parameter (rather than the text value selected):

e.g. https://jsfiddle.net/yz7tu49b/

$option.prop('selected', true);  // Will add selected="selected" to the tag

Note 3 - allow for unknown values:

If you use val() to select an <option>, but the val is not matched (might happen depending on the source of the values), then "nothing" is selected and $select.val() will return null.

So, for the example shown, and for the sake of robustness, you could use something like this https://jsfiddle.net/1250Ldqn/:

var $select = $('.selDiv .opts');
$select.val("SEL2");
if ($select.val() == null) {
  $select.val("DEFAULT");
}

Note 4 - exact text match:

If you want to match by exact text, you can use a filter with function. e.g. https://jsfiddle.net/yz7tu49b/2/:

var $select = $('.selDiv .opts');
$select.children().filter(function(){
    return this.text == "Selection 2";
}).prop('selected', true);

although if you may have extra whitespace you may want to add a trim to the check as in

    return $.trim(this.text) == "some value to match";

Note 5 - match by index

If you want to match by index just index the children of the select e.g. https://jsfiddle.net/yz7tu49b/3/

var $select = $('.selDiv .opts');
var index = 2;
$select.children()[index].selected = true;

Although I tend to avoid direct DOM properties in favour of jQuery nowadays, to future-proof code, so that could also be done as https://jsfiddle.net/yz7tu49b/5/:

var $select = $('.selDiv .opts');
var index = 2;
$select.children().eq(index).prop('selected', true);

Note 6 - use change() to fire the new selection

In all the above cases, the change event does not fire. This is by design so that you do not wind up with recursive change events.

To generate the change event, if required, just add a call to .change() to the jQuery select object. e.g. the very first simplest example becomes https://jsfiddle.net/yz7tu49b/7/

var $select = $('.selDiv .opts');
$select.val("SEL2").change();

There are also plenty of other ways to find the elements using attribute selectors, like [value="SEL2"], but you have to remember attribute selectors are relatively slow compared to all these other options.


r
raddevus

Using jquery-2.1.4, I found the following answer to work for me:

$('#MySelectionBox').val(123).change();

If you have a string value try the following:

$('#MySelectionBox').val("extra thing").change();

Other examples did not work for me so that's why I'm adding this answer.

I found the original answer at: https://forum.jquery.com/topic/how-to-dynamically-select-option-in-dropdown-menu


p
perumal N

Exactly it will work try this below methods

For normal select option

<script>    
    $(document).ready(function() {
    $("#id").val('select value here');
       });
        </script>

For select 2 option trigger option need to use

<script>    
        $(document).ready(function() {
        $("#id").val('select value here').trigger('change');
           });
            </script>

J
João Paulo Oliveira
   $(elem).find('option[value="' + value + '"]').attr("selected", "selected");

Thank you for your post, but what does this answer add to the conversation that is not included in the accepted answers?
if there is an option already selected then this will fail as a drop-down can't have more than one item selected unless it is a multi-select. You need to do .prop('selected',true)
U
Udo Held

You could name the select and use this:

$("select[name='theNameYouChose']").find("option[value='theValueYouWantSelected']").attr("selected",true);

It should select the option you want.


J
Jay Corbett

Answering my own question for documentation. I'm sure there are other ways to accomplish this, but this works and this code is tested.

<html>
<head>
<script language="Javascript" src="javascript/jquery-1.2.6.min.js"></script>
<script type="text/JavaScript">

$(function() {
    $(".update").bind("click",      // bind the click event to a div
        function() {
            var selectOption = $('.selDiv').children('.opts') ;
            var _this = $(this).next().children(".opts") ;

            $(selectOption).find("option[index='0']").attr("selected","selected");
//          $(selectOption).find("option[value='DEFAULT']").attr("selected","selected");
//          $(selectOption).find("option[text='Default']").attr("selected","selected");


//          $(_this).find("option[value='DEFAULT']").attr("selected","selected");
//          $(_this).find("option[text='Default']").attr("selected","selected");
//          $(_this).find("option[index='0']").attr("selected","selected");

    }); // END Bind
}); // End eventlistener

</script>
</head>
<body>
<div class="update" style="height:50px; color:blue; cursor:pointer;">Update</div>
<div class="selDiv">
        <select class="opts">
            <option selected value="DEFAULT">Default</option>
            <option value="SEL1">Selection 1</option>
            <option value="SEL2">Selection 2</option>
        </select>
    </div>
</body>
</html>

N
Nick Tsai

For setting select value with triggering selected:

$('select.opts').val('SEL1').change();

For setting option from a scope:

$('.selDiv option[value="SEL1"]')
    .attr('selected', 'selected')
    .change();

This code use selector to find out the select object with condition, then change the selected attribute by attr().

Futher, I recommend to add change() event after setting attribute to selected, by doing this the code will close to changing select by user.


p
perumal N

Try this

you just use select field id instead of #id (ie.#select_name)

instead of option value use your select option value

 <script>
    $(document).ready(function() {
$("#id option[value='option value']").attr('selected',true);
   });
    </script>

M
Miguel

I use this, when i know the index of the list.

$("#yourlist :nth(1)").prop("selected","selected").change();

This allows the list to change, and fire the change event. The ":nth(n)" is counting from index 0


Y
Yoel Duran
    $('#select option[data-id-estado="3"]').prop("selected",true).trigger("change");

// or

    $('#select option[value="myValue"]').prop("selected",true).trigger("change");

Please edit your answer so the code is formatted as code. Do this by using the toolbar, or by simply indenting all lines of each code block by four spaces.
C
CRUSADER

i'll go with:-

$("select#my-select option") .each(function() { this.selected = (this.text == myVal); });

P
Pratik Kamani
/* This will reset your select box with "-- Please Select --"   */ 
    <script>
    $(document).ready(function() {
        $("#gate option[value='']").prop('selected', true);
    });
    </script>

A
Andrej Gaspar

For Jquery chosen if you send the attribute to function and need to update-select option

$('#yourElement option[value="'+yourValue+'"]').attr('selected', 'selected');
$('#editLocationCity').chosen().change();
$('#editLocationCity').trigger('liszt:updated');

F
FLICKER

if you want to not use jQuery, you can use below code:

document.getElementById("mySelect").selectedIndex = "2";

B
Bud Damyanov

The $('select').val('the_value'); looks the right solution and if you have data table rows then:

$row.find('#component').val('All');

M
Md. Russel Hussain

Thanks for the question. Hope this piece of code will work for you.

var val = $("select.opts:visible option:selected ").val();

R
Richard

There are a few suggestions why you should use prop instead of attr. Definitely use prop as I've tested both and attr will give you weird results except for the simplest of cases.

I wanted a solution where selecting from an arbitrarily grouped select options automatically selected another select input on that same page. So for instance, if you have 2 dropdowns - one for countries, and the other for continents. In this scenario, selecting any country automatically selected that country's continent on the other continent dropdown.

$("#country").on("change", function() { //get continent var originLocationRegion = $(this).find(":selected").data("origin-region"); //select continent correctly with prop $('#continent option[value="' + originLocationRegion + '"]').prop('selected', true); }); $("#country2").on("change", function() { //get continent var originLocationRegion = $(this).find(":selected").data("origin-region"); //select continent wrongly with attr $('#continent2 option[value="' + originLocationRegion + '"]').attr('selected', true); });

Props to the good stuff ;)


Attributing the bad stuff to attr

As seen in the code snippet, prop works correctly every time, but attr fails to select properly once the option has been selected once.

Keypoint: We're usually interested in the property of the attribute, so its safer to use prop over attr in most situations.