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


420

我有以下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函数,如何在列表中选择适当的选项?


查看我的答案以比较不同方法的性能
Toskan 2012年

Answers:


532

您可以使用此功能:

selectElement('leaveCode', '11')

function selectElement(id, valueToSelect) {    
    let element = document.getElementById(id);
    element.value = valueToSelect;
}

4
很好的答案,这比遍历选项更容易。并且符合标准:dev.w3.org/html5/spec/…。如果存在浏览器不兼容(当然有:),我将非常有兴趣知道它们是什么。这通常是您在ppk上需要依靠的东西,但是他顽固地拒绝出现在我对此主题的搜索中。
菲洛

9
那多重选择呢?如果有多个选项(至少在Chrome 25中),这似乎不起作用。
Georgii Ivankin

2
正如@ ring0所指出的,当valueToSelect不存在时,它将在chrome中插入一个空白条目。而IE和firefox保留最后选择的值。
Karthik Bose

1
IE注意:<option>必须具有value ='valueToSelect'属性。您不能在<option> .. </ option>中将显示文本用作valueToSelect
Peter Quiring

4
如果您需要触发变更事件,则还应该这样做: element.dispatchEvent(new Event('change'));
Patrick James McDougle,

120

如果您使用的是jQuery,则还可以执行以下操作:

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

这将选择<option>值为14的。


使用纯Javascript,这也可以通过以下两种Document方法实现:

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

    document.querySelector('#leaveCode').value = '14'
  • document.getElementById()就像函数名称所暗示的那样,使用更成熟的方法使用,您可以根据以下元素选择一个元素id

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

您可以运行下面的代码片段以查看这些方法和实际使用的jQuery函数:


4
这也可以用于多选。只需将字符串数组而不是单个字符串传递给'val'函数。请参阅:stackoverflow.com/a/16583001/88409
Triynko 2015年

有没有办法通过这样做来触发$('#leaveCode')。on('change',function()?
Lieuwe

5
$(“#leaveCode”)。val(“ 14”)。change();
罗伦(Loren)


16

不回答问题,但是您也可以按索引选择,其中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;

4
不应该形成Obj.leaveCode [i] .selected = true; 是formObj.options [i] .selected = true; ?
David Christopher Reynolds,

14

我比较了不同的方法:

比较如何使用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个元素的select的输出:

  • 1毫秒
  • 58毫秒
  • 612毫秒

使用Firefox10。注意:我进行此测试的唯一原因是,由于jQuery在我们的列表上的表现非常差,有大约2000个条目(选项之间的文本较长)。val()之后大约有2秒的延迟

还要注意:我根据实际值而不是文本值来设置值。


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

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


9

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

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

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

在AngularJS应用中,其中有必需的 <select>元素。

它们都不起作用,因为未触发AngularJS表单验证。尽管选择了正确的选项(并以表格形式显示),但输入仍然无效(仍然存在ng-pristineng-invalid类)。

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

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

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

当您已经可以使用Angular时为何使用jQuery?当使用Angular本身时,您是否有能力设置值,并具有触发更改的内置支持(不知道,我使用React,只是在5秒钟的google之后找到了这篇文章:stackoverflow.com/questions/ 50302062 /…)?因为那意味着您不必再为±30kb的库“只为此”而
烦恼Angular

3

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


3

如果需要,最简单的方法是:
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是您的带有选择选项的页面。请注意,页面网址具有?option = 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个步骤,就可以完美地工作。


1

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

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

1

假设您的表单名为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

应该遵循以下原则:

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;
}

0
function selecetElement() {
 var selectedValue = document.getElementById('leaveCode');
 selectedValue.value = "11";
}

2
在为已有11个已有问题的11年问题添加答案时,指出您的答案要解决问题的新方面非常重要。如果您不这样做,并且所做的更改很微妙,则可能会错过,并且您的答案将作为较晚的副本被删除。仅对代码的答案几乎总是可以通过添加一些有关其工作方式和原因的解释来加以改进。
杰森·艾勒

-1

如果使用PHP,则可以尝试以下操作:

$value = '11';
$first = '';
$second = '';
$third = '';
$fourth = '';

switch($value) {
            case '10' :
                $first = 'selected';
            break;
            case '11' :
                $second = 'selected';
            break;
            case '14' :
                $third = 'selected';
            break;
            case '17' :
                $fourth = 'selected';
            break;
        }

echo'
<select id="leaveCode" name="leaveCode">
  <option value="10" '. $first .'>Annual Leave</option>
  <option value="11" '. $second .'>Medical Leave</option>
  <option value="14" '. $third .'>Long Service</option>
  <option value="17" '. $fourth .'>Leave Without Pay</option>
</select>';

-1

您最可能希望这样做:

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

要么

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

8
这是假设OP虽然正在使用JQuery
Barry Michael Doyle

2
@BarryMichaelDoyle,不是,因为问题的标题都以结尾using JavaScript
Iulian Onofrei

-6

恐怕目前无法测试,但是在过去,我相信我必须给每个选项标签指定一个ID,然后执行以下操作:

document.getElementById("optionID").select();

如果这不起作用,也许它将使您更接近解决方案:P


3
HTMLOptionElement不具有select()方法(它没有定义的所有HTML元素比标准集的任何其他方法)。但是,您可以将selected属性设置为true。
MrWhite 2012年
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.