如何使用JavaScript以编程方式设置选择框元素的值?

bra*_*zoo 375 html javascript dom

我有以下HTML <select>元素:

<select id="leaveCode" name="leaveCode">
  <option value="10">Annual Leave</option>
  <option value="11">Medical Leave</option>
  <option value="14">Long Service</option>
  <option value="17">Leave Without Pay</option>
</select>
Run Code Online (Sandbox Code Playgroud)

使用带有leaveCode数字作为参数的JavaScript函数,如何在列表中选择适当的选项?

Mit*_*ers 478

selectElement('leaveCode', '11')

function selectElement(id, valueToSelect) {    
    let element = document.getElementById(id);
    element.value = valueToSelect;
}
Run Code Online (Sandbox Code Playgroud)

  • 我知道它适用于IE,FF和Safari.哪里不起作用? (23认同)
  • 如果您需要触发更改事件,您还应该这样做:`element.dispatchEvent(new Event('change'));` (14认同)
  • 那么多选呢?这似乎不适用于多个选项(至少在Chrome 25中). (8认同)
  • 很好的答案,这比循环选项更容易.它符合标准:http://dev.w3.org/html5/spec/the-select-element.html#the-select-element.如果有浏览器不兼容(当然有:)我会非常有兴趣知道它们是什么.这就是你通常依靠ppk的那种东西,但他顽固地拒绝出现在我对这个话题的搜索中. (3认同)
  • 较早版本的IE.但现在没关系,它是2012年. (3认同)
  • 正如@ ring0指出的那样,当valueToSelect不存在时,它会在chrome中插入一个空白条目.而IE和Firefox保留最后选择的值. (2认同)

Ein*_*son 108

如果你使用的是jQuery,你也可以这样做

$('#leaveCode').val('14');
Run Code Online (Sandbox Code Playgroud)

这将选择值为14的选项

编辑:

使用普通的Javascript,这也可以通过两种Document方法实现

使用querySelector,您可以选择基于CSS选择器的元素

document.querySelector('#leaveCode').value = '14'
Run Code Online (Sandbox Code Playgroud)

或者更成熟的方法,使用getDocumentById,就像函数的名称所暗示的那样,让你选择一个基于那里的元素<option>

document.getElementById('leaveCode').value = '14'
Run Code Online (Sandbox Code Playgroud)

您可以运行剪切的波纹管代码来查看这些方法和jQuery函数.

const jQueryFunction = () => {
  
  $('#leaveCode').val('14'); 
  
}

const querySelectorFunction = () => {
  
  document.querySelector('#leaveCode').value = '14' 
  
}

const getElementByIdFunction = () => {
  
  document.getElementById('leaveCode').value='14' 
  
}
Run Code Online (Sandbox Code Playgroud)
input {
  display:block;
  margin: 10px;
  padding: 10px
}
Run Code Online (Sandbox Code Playgroud)
<select id="leaveCode" name="leaveCode">
  <option value="10">Annual Leave</option>
  <option value="11">Medical Leave</option>
  <option value="14">Long Service</option>
  <option value="17">Leave Without Pay</option>
</select>

<input type="button" value="$('#leaveCode').val('14');" onclick="jQueryFunction()" />
<input type="button" value="document.querySelector('#leaveCode').value = '14'" onclick="querySelectorFunction()" />
<input type="button" value="document.getElementById('leaveCode').value = '14'" onclick="getElementByIdFunction()" />

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

  • .$( "#leaveCode")VAL( "14")变化(); (5认同)
  • 这也可以用于多选; 只是将一个字符串数组传递给'val'函数而不是单个字符串.请参阅:http://stackoverflow.com/a/16583001/88409 (3认同)

And*_*ges 28

function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
Run Code Online (Sandbox Code Playgroud)


Kam*_*ski 18

短的

这是威廉答案的尺寸改进

leaveCode.value = '14';
Run Code Online (Sandbox Code Playgroud)

  • 这不应该使用 jquery 选择器之类的吗?或者我今天早上速度很慢,可以简单地在 js 中调用 some_id.value 吗? (3认同)
  • 这应该是公认的答案! (3认同)

Cha*_*ert 15

没有回答问题,但您也可以通过索引进行选择,其中i是您要选择的项目的索引:

var formObj = document.getElementById('myForm');
formObj.leaveCode[i].selected = true;
Run Code Online (Sandbox Code Playgroud)

您还可以循环浏览项目以通过循环显示值进行选择:

for (var i = 0, len < formObj.leaveCode.length; i < len; i++) 
    if (formObj.leaveCode[i].value == 'xxx') formObj.leaveCode[i].selected = true;
Run Code Online (Sandbox Code Playgroud)

  • 不应该formObj.leaveCode [i] .selected = true; 是formObj.options [i] .selected = true; ? (3认同)

Tos*_*kan 13

我比较了不同的方法:

比较如何使用JS或jQuery设置选择值的不同方法

码:

$(function() {
    var oldT = new Date().getTime();
     var element = document.getElementById('myId');
    element.value = 4;
    console.error(new Date().getTime() - oldT);


    oldT = new Date().getTime();
    $("#myId option").filter(function() {
        return $(this).attr('value') == 4;
    }).attr('selected', true);
    console.error(new Date().getTime() - oldT);


    oldT = new Date().getTime();
    $("#myId").val("4");
    console.error(new Date().getTime() - oldT);


});
Run Code Online (Sandbox Code Playgroud)

具有~4000个元素的选择上的输出:

1毫秒

58毫秒

612毫秒

使用Firefox 10.注意:我做这个测试的唯一原因是因为jQuery在我们的列表上表现得非常糟糕,有大约2000个条目(它们在选项之间有更长的文本).在val()之后我们有大约2秒的延迟

另请注意:我根据实际值而不是文本值设置值

  • 我们案例中的自动完成是建立在选择列表之上的.优点是您不必编程任何东西,只需重复使用即可.如果选择很重要或经常使用,那么具有完全ajax支持的自动完成可能就是您想要的.但由于所有选择列表都不是这样,我确信有一些更重要的改进;-) (3认同)

Wil*_*iam 9

document.getElementById('leaveCode').value = '10';
Run Code Online (Sandbox Code Playgroud)

这应该将选择设置为"年假"


lum*_*i77 8

我尝试了上面基于JavaScript/jQuery的解决方案,例如:

$("#leaveCode").val("14");
Run Code Online (Sandbox Code Playgroud)

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
Run Code Online (Sandbox Code Playgroud)

在AngularJS应用程序中,有一个必需的 <select>元素.

它们都不起作用,因为不会触发AngularJS表单验证.虽然选择了正确的选项(并显示在表单中),但输入仍然无效(ng-pristineng-invalid类仍然存在).

要强制进行AngularJS验证,请在选择选项后调用jQuery change():

$("#leaveCode").val("14").change();
Run Code Online (Sandbox Code Playgroud)

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
Run Code Online (Sandbox Code Playgroud)