536

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

4

17 回答 17

670

您可以使用此功能:

selectElement('leaveCode', '11')

function selectElement(id, valueToSelect) {    
    let element = document.getElementById(id);
    element.value = valueToSelect;
}
于 2008-09-17T01:31:38.607 回答
141

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

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

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


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

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

    document.querySelector('#leaveCode').value = '14'
    
  • 使用更成熟的方法 with 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>

于 2010-12-23T15:00:15.430 回答
30
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
于 2008-09-17T03:04:31.847 回答
20

不回答问题,但您也可以按索引选择,其中 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;
于 2008-09-17T01:32:10.930 回答
16

我比较了不同的方法:

比较如何使用 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);
});

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

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

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

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

于 2012-08-10T15:50:20.937 回答
13
document.getElementById('leaveCode').value = '10';

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

于 2008-09-17T01:34:00.067 回答
12

我尝试了上述基于 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();
于 2015-06-01T12:38:00.713 回答
8

最短的

这是威廉答案的尺寸改进

leaveCode.value = '14';

leaveCode.value = '14';
<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>

于 2020-09-14T11:02:01.477 回答
4

如果您需要,最简单的方法是:
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 个步骤,就可以完美运行。

于 2011-03-18T00:53:31.280 回答
3

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

于 2008-09-17T01:32:56.747 回答
2

应该是这样的:

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;
}
于 2008-09-17T01:35:28.083 回答
2

假设您的表单名为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;
    }
  }
}
于 2008-09-17T03:03:01.493 回答
1

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

function SelectElement(selectElementId, valueToSelect)
{    
    var element = document.getElementById(selectElementId);
    element.value = valueToSelect;
}
于 2008-09-17T01:43:51.370 回答
0

这里提到的大部分代码对我都不起作用!

最后,这行得通

window.addEventListener很重要,否则,您的 JS 代码将在选项中获取值之前运行

    window.addEventListener("load", function () {
            // Selecting Element with ID - leaveCode  //
            var formObj = document.getElementById('leaveCode');

            // Setting option as selected
            let len;
            for (let i = 0, len = formObj.length; i < len; i++){
                if (formObj[i].value == '<value to show in Select>') 
                 formObj.options[i].selected = true;
            }
    });

希望这可以帮助!

于 2020-08-12T13:04:54.153 回答
-2

你很可能想要这个:

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

或者

$('select').prop('selectedIndex', 3); 
于 2016-05-25T19:07:03.747 回答
-3

如果使用 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>';
于 2014-01-29T05:17:07.593 回答
-6

恐怕我目前无法对此进行测试,但在过去,我相信我必须给每个选项标签一个 ID,然后我做了类似的事情:

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

如果这不起作用,也许它会让你更接近解决方案:P

于 2008-09-17T01:32:38.247 回答