it-swarm.cn

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

我有以下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>

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

338
brasskazoo
SelectElement("leaveCode", valueToSelect)

function SelectElement(id, valueToSelect)
{    
    var element = document.getElementById(id);
    element.value = valueToSelect;
}
430
Mitchel Sellers

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

$('#leaveCode').val('14');

这将选择值为14的<option>


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

  • 使用 document.querySelector ,您可以根据CSS选择器选择一个元素:

    document.querySelector('#leaveCode').value = '14'
    
  • 使用更成熟的方法和 document.getElementById() ,这将作为函数的名称暗示,让你根据它的id选择一个元素:

    document.getElementById('leaveCode').value = '14'
    

您可以运行以下代码剪切以查看这些方法和jQuery函数:

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

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

const getElementByIdFunction = () => {
  
  document.getElementById('leaveCode').value='14' 
  
}
input {
  display:block;
  margin: 10px;
  padding: 10px
}
<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>
96
Einar Ólafsson
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
28
Andrew Hedges

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

var formObj = document.getElementById('myForm');
formObj.leaveCode[i].selected = true;

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

for (var i = 0, len < formObj.leaveCode.length; i < len; i++) 
    if (formObj.leaveCode[i].value == 'xxx') formObj.leaveCode[i].selected = true;
14
Chase Seibert

我比较了不同的方法:

使用JS或jQuery设置select值的不同方法的比较

码:

$(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);


});

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

1毫秒

58毫秒

612毫秒

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

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

13
Toskan
document.getElementById('leaveCode').value = '10';

这应该将选择设置为“年假”

9
William

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

$("#leaveCode").val("14");

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;

在AngularJS应用程序中,其中有一个 required <select>元素。

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

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

$("#leaveCode").val("14").change();

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
7
lumi77

function foo(value)
{
    var e = document.getElementById('leaveCode');
    if(e) e.value = value;
}
3
mmattax

如果您需要,最简单的方法:
1)单击定义选择选项的按钮
2)转到另一个页面,其中选择选项是
3)在另一页上选择该选项值

1) 您的按钮链接(例如,在主页上)

<a onclick="location.href='contact.php?option=1';" style="cursor:pointer;">Sales</a>
<a onclick="location.href='contact.php?option=2';" style="cursor:pointer;">IT</a>

(其中 contact.php 是包含选择选项的页面。注意页面网址有?选项= 1或2)

2) 把这个代码放在你的第二页(我的情况 contact.php

<?
if (isset($_GET['option']) && $_GET['option'] != "") {
$pg = $_GET['option'];              
} ?>

3) 选择选项值,具体取决于单击的按钮

<select>
<option value="Sales" <? if ($pg == '1') { echo "selected"; } ?> >Sales</option>
<option value="IT" <? if ($pg == '2') { echo "selected"; } ?> >IT</option>
</select>

.. 等等。
因此,这是通过URL中的GET将值传递到另一个页面(使用选择选项列表)的简单方法。没有形式,没有ID ..只需3个步骤,它完美无缺。

3
Lana

应该是这样的:

function setValue(inVal){
var dl = document.getElementById('leaveCode');
var el =0;
for (var i=0; i<dl.options.length; i++){
  if (dl.options[i].value == inVal){
    el=i;
    break;
  }
}
dl.selectedIndex = el;
}
1
Stephen Wrighton

假设您的表单名为 form1

function selectValue(val)
{
  var lc = document.form1.leaveCode;
  for (i=0; i&lt;lc.length; i++)
  {
    if (lc.options[i].value == val)
    {
        lc.selectedIndex = i;
        return;
    }
  }
}
1
Milan Babuškov

为什么不为元素的Id添加变量并使其成为可重用的函数?

function SelectElement(selectElementId, valueToSelect)
{    
    var element = document.getElementById(selectElementId);
    element.value = valueToSelect;
}
1
Robert Swisher

你最有可能想要这个:

$("._statusDDL").val('2');

OR

$('select').prop('selectedIndex', 3); 
0
user5846985