我有以下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>
如果需要,最简单的方法是:
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是带有选择选项的页面。注意页面url有?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将值传递到另一个页面(带有选择选项列表)的简单方法。没有表格,没有身份证件。只需3步,效果完美。
我比较了不同的方法:
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秒的延迟。
还要注意:我设置的值取决于实际值,而不是文本值。
我尝试了上述基于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();