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


当前回答

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

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

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

其他回答

你可以使用这个函数:

函数selectElement(id, valueToSelect) { let element = document.getElementById(id); 元素。value = valueToSelect; } selectElement(‘leaveCode’,‘11’); <select id="leaveCode" name="leaveCode"> <option value="10">年假</option> . <option value="11">病假</option> . <option value="14">长业务</option> . <option value="17">无薪休假</option> < /选择>

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

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

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

如果你正在使用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;
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);