我有以下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函数作为参数,如何在列表中选择适当的选项?
答案 0 :(得分:432)
SelectElement("leaveCode", valueToSelect)
function SelectElement(id, valueToSelect)
{
var element = document.getElementById(id);
element.value = valueToSelect;
}
答案 1 :(得分:98)
如果您使用的是jQuery,您也可以这样做:
$('#leaveCode').val('14');
这将选择值为14的<option>
。
使用普通的Javascript,这也可以通过两个Document
methods:
使用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>
答案 2 :(得分:28)
function setSelectValue (id, val) {
document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
答案 3 :(得分:14)
不回答问题,但您也可以按索引选择,其中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 :(得分:13)
我比较了不同的方法:
Comparison of the different ways on how to set a value of a select with JS or 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 ms
58 ms
612 ms
使用Firefox 10.注意:我进行此测试的唯一原因是因为jQuery在我们的列表中表现得非常差,有大约2000个条目(它们之间的选项有更长的文本)。 在val()
之后我们有大约2秒的延迟另请注意:我根据实际值设置值,而不是文本值
答案 5 :(得分:9)
document.getElementById('leaveCode').value = '10';
这应该将选择设置为“年假”
答案 6 :(得分:7)
我尝试了上述基于JavaScript / jQuery的解决方案,例如:
$("#leaveCode").val("14");
和
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
在AngularJS应用中,其中有必需&lt; select&gt;元件。
它们都不起作用,因为不会触发AngularJS表单验证。虽然选择了正确的选项(并显示在表单中),但输入仍然无效( ng-pristine 和 ng-invalid 类仍然存在)。
要强制进行AngularJS验证,请在选择选项后调用jQuery change():
$("#leaveCode").val("14").change();
和
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
答案 7 :(得分:3)
function foo(value)
{
var e = document.getElementById('leaveCode');
if(e) e.value = value;
}
答案 8 :(得分: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 是包含所选选项的页面。请注意页面网址有?选项= 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个步骤就可以完美。
答案 9 :(得分: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;
}
答案 10 :(得分:1)
为什么不为元素的Id添加变量并使其成为可重用的函数?
function SelectElement(selectElementId, valueToSelect)
{
var element = document.getElementById(selectElementId);
element.value = valueToSelect;
}
答案 11 :(得分:1)
假设您的表单名为 form1 :
function selectValue(val)
{
var lc = document.form1.leaveCode;
for (i=0; i<lc.length; i++)
{
if (lc.options[i].value == val)
{
lc.selectedIndex = i;
return;
}
}
}
答案 12 :(得分:0)
你很可能想要这个:
$("._statusDDL").val('2');
OR
$('select').prop('selectedIndex', 3);
答案 13 :(得分: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;
}
});
希望,这会有所帮助!
答案 14 :(得分:0)
this['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>
SELECT *
FROM TB_ADT_AEAT_ESTADOS
WHERE F_MODIF < SYSDATE-5/1440;
答案 15 :(得分:-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>';
答案 16 :(得分:-5)
我担心此刻我无法测试这一点,但在过去,我认为我必须给每个选项标签一个ID,然后我做了类似的事情:
document.getElementById("optionID").select();
如果这不起作用,也许它会让你更接近解决方案:P