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

我有以下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>

使用JavaScript函数与leaveCode数字作为参数,我如何在列表中选择适当的选项?

1270938 次浏览

你可以使用这个函数:

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


selectElement('leaveCode', '11');
<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>

如果你也想触发onchange事件,你可以使用:

element.dispatchEvent(new Event('change'))

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

恐怕我现在无法测试这个,但在过去,我相信我必须给每个选项标签一个ID,然后我做了如下的事情:

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

如果这行不通,也许它会让你更接近一个解决方案:P


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

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

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

应该是这样的:

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

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

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

假设你的表单名为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;
}
}
}
function setSelectValue (id, val) {
document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);

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

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

这将选择值为14的<option>


使用简单的Javascript,这也可以通过两个# EYZ0方法实现:

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

    document.querySelector('#leaveCode').value = '14'
    
  • Using the more established approach with document.getElementById(), that will, as the name of the function implies, let you select an element based on its id:

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

You can run the below code snipped to see these methods and the jQuery function in action:

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)

把这个代码放在你的第二页(我的案例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>
< p > . .等等。
因此,这是通过url中的GET将值传递到另一个页面(带有选择选项列表)的简单方法。没有表格,没有身份证件。

.

.

如果使用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>';

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

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

而且

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

在AngularJS应用中,有一个要求 <元素。

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

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

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

而且

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

你很可能想要这个:

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

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

这里提到的大部分代码都不适合我!

最后,这招奏效了

< >强窗口。addEventListener是重要的,否则,你的JS代码将在Options中获取值之前运行

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

希望这有帮助!

这是威廉回答的尺寸改进

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>