我有一个选择字段,其中有一些选项。现在我需要用jQuery选择其中一个选项。但是,当我只知道必须选择的选项的值时,我该怎么做呢?

我有以下HTML:

<div class="id_100">
  <select>
    <option value="val1">Val 1</option>
    <option value="val2">Val 2</option>
    <option value="val3">Val 3</option>
  </select>
</div>

我需要选择值为val2的选项。如何做到这一点呢?

这是一个演示页面: http://jsfiddle.net/9Stxb/


当前回答

试试这个。

它简单而有效,是JavaScript + jQuery的致命组合。

SelectComponent:

<select id="YourSelectComponentID">
    <option value="0">Apple</option>
    <option value="2">Banana</option>
    <option value="3">Cat</option>
    <option value="4">Dolphin</option>
</select>

选择:

document.getElementById("YourSelectComponentID").value = 4;

现在您的选项4将被选中。您可以这样做,在默认情况下选择启动时的值。

$(function(){
   document.getElementById("YourSelectComponentID").value = 4;
});

或者创建一个简单的函数,将行放入其中,并在anyEvent上调用该函数来选择该选项

jQuery + JavaScript的混合物的魔力…

其他回答

您可以使用属性选择器[attributename=optionalvalue]选择任何属性及其值,因此在您的情况下,您可以选择该选项并设置所选属性。

$("div.id_100 > select > option[value=" + value + "]").prop("selected",true);

其中value是您希望通过的值。

如果您需要删除任何先前选择的值,就像多次使用这种情况一样,您需要稍微更改它,以便首先删除所选的属性

$("div.id_100 option:selected").prop("selected",false);
$("div.id_100 option[value=" + value + "]")
        .prop("selected",true);

这肯定适用于选择控件:

$('select#ddlCountry option').each(function () {
if ($(this).text().toLowerCase() == co.toLowerCase()) {
    this.selected = true;
    return;
} });

对我来说,下面的工作就完成了

$("div.id_100").val("val2").change();

你可以用不同的方法来实现这一点(记住,如果要操作一个元素,最好给它一个id或类,而不是让它的父元素是一个id或类):

在这里,由于div有一个类来针对它内部的select,代码将是:

$("div.id_100 select").val("val2");

or

$('div.id_100  option[value="val2"]').prop("selected", true);

如果给类选择自己,代码将是:

$(".id_100").val("val2");

or

$('.id_100 option[value=val2]').attr('selected','selected');

or

$('.id_100 option')
    .removeAttr('selected')
    .filter('[value=val1]')
    .attr('selected', true);

要动态传递值,代码将是:

值=“val2”;

$("div.id_100 select").val(valu);
$("div.id_100 > select > option[value=" + valu + "]").prop("selected",true);

如果元素是通过Ajax添加的,你必须给你的元素'id',并使用:

window.document.getElementById

否则,你将不得不给你的元素和使用的“类”

window.document.getElementById

您还可以通过索引号来选择select元素的值。

如果你给了你的选择元素ID,代码将是:

window.document.getElementById('select_element').selectedIndex = 4;

记住,当您像上面所说的那样更改选择值时,不会调用change方法。

也就是说,如果你写了一些代码来改变选择,上面的方法会改变选择值,但不会触发改变。

要触发change函数,必须在末尾添加.change()。

所以代码是:

$("#select_id").val("val2").change();

选择值后使用change()事件。从文档中可以看到:

如果字段在内容没有改变的情况下失去焦点,则不会触发事件。要手动触发事件,请应用不带参数的.change():

$("#select_id").val("val2").change();

更多信息请参见.change()。