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


当前回答

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

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

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


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

与文档。querySelector,你可以根据CSS选择器选择一个元素: document.querySelector(“# leaveCode”)。Value = '14' 使用更成熟的document.getElementById()方法,正如函数名称所暗示的那样,它将允许您根据其id选择元素: . 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>

其他回答


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

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

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

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


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

与文档。querySelector,你可以根据CSS选择器选择一个元素: document.querySelector(“# leaveCode”)。Value = '14' 使用更成熟的document.getElementById()方法,正如函数名称所暗示的那样,它将允许您根据其id选择元素: . 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>

没有回答这个问题,但是你也可以通过索引进行选择,其中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;

你很可能想要这个:

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

OR

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

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

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

and

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

在AngularJS应用中,有一个必选的<select>元素。

它们都不起作用,因为AngularJS的表单验证没有启动。尽管选择了正确的选项(并显示在表单中),但输入仍然无效(仍然存在ng- primitive和ng-invalid类)。

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

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

and

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