我有一个选择字段,其中有一些选项。现在我需要用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/


当前回答

最好在设置select value之后使用change()。

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

通过这样做,代码将关闭更改用户的选择,解释包括在JS提琴:

JS小提琴

其他回答

当控件是动态创建的,而不是在静态HTML页面中时,选择下拉控件没有动态更改,这似乎是一个问题。

在jQuery中,这个解决方案为我工作。

$('#editAddMake').val(result.data.make_id);
$('#editAddMake').selectmenu('refresh');

就像附录一样,第一行代码没有第二行,实际上是透明的,在设置索引后检索所选索引是正确的,如果您实际单击控件,它将显示正确的项目,但这并没有反映在控件的顶部标签中。

<select name="contribution_status_id" id="contribution_status_id" class="form-select">
    <option value="1">Completed</option>
    <option value="2">Pending</option>
    <option value="3">Cancelled</option>
    <option value="4">Failed</option>
    <option value="5">In Progress</option>
    <option value="6">Overdue</option>
    <option value="7">Refunded</option>
</select>

按值设置为Pending状态:

$('#contribution_status_id').val("2");

没有任何理由去想太多。您所要做的就是访问和设置一个属性。就是这样。

好的,一些基本的DOM:

如果你在JavaScript中直接这样做,你会这样做:

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

但你不是用JavaScript,而是用jQuery。在jQuery中,你想要使用.prop()函数来设置属性,所以你会这样做:

$("#my_stuff").prop('selectedIndex', 4);

不管怎样,只要确保你的id是唯一的。否则,你会用头撞墙,想知道为什么这行不通。

选择值为'val2'的选项:

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

我已经准备了一个小的JQuery扩展,删除所有不必要的选项和隐藏所选的选项,用户只看到一个值在选择字段

$.prototype.makeReadOnly = function (canClick = false) {
    $(this).each(function () {
        $(this).readonly = true;
        if ($(this).is("select")) {
            if(!canClick) $(this).mousedown(function () { event.preventDefault(); }).keydown(function () { event.preventDefault(); });
            $(this).find('option:not(:selected)').remove();
            $(this).find('option').hide();
        }
    });
}

然后你可以让所有的选择都是只读的

$("select").makeReadOnly();

或者只选择特定的只读类

$("select.read-only").makeReadOnly();