我有以下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 号码作为一个参数,如何选择适当的选项清单?

有帮助吗?

解决方案

SelectElement("leaveCode", valueToSelect)

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

其他提示

如果您使用的是jQuery你也可以这样做:

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

这将选择 <option> 值的14.


与普通Javascript,这也可以实现与两个 Document 方法:

  • document.querySelector, 你可以选择一个元素的基础上CSS选择:

    document.querySelector('#leaveCode').value = '14'
    
  • 使用更多的建立的方法 document.getElementById(), 那将会,正如其名称的功能意味着,让你选择一个元素的基础上它的 id:

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

你可以运行以下代码剪断看到这些方法和s功能的行动:

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 setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);

不回答这个问题,但也可以选择通过指数,在那里我是项目的索引你的愿望来选择:

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;

我比较了不同的方法:

比较不同的方式如何设定一个数值的选择与JS或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元素:

1ms

58ms

612ms

有Firefox10.注:的唯一原因是我做的试验,是因为jQuery进行的超级难我们的名单上有~2000年的条目(他们有较长的文本之间的选择)。我们有大约2s延后瓦尔()

注:我设定的价值取决于真正的价值,不该文本值

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

应该设置选择"年假"

我试过的上述JavaScript级为基础的解决方案,例如:

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

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

在一个人们的生活产生了重要的应用程序,在那里有一个 需要 <select> 元素。

他们没有工作,因为人们的生活产生了重要形式,验证不是被解雇。虽然正确的选择选择(和显示形式)、输入仍然是无效的(ng-纯净ng-无效 类仍然存在)。

为力的人们的生活产生了重要的验证,呼jQuery 改变() 选择后一种选择:

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

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

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

最简单的方法如果你需要:
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 是你的网页,与选择选项。注意页面的网址?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>

..等等。
因此,这是一个简单的方法传递的价值,另一个网页(与选择选项清单)通过获得在网址。没有任何形式,没有Id..只是3个步骤,它的工作完美的。

为什么不添加一个变量元素的身份,并使它成为一个可重复使用的功能吗?

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

你很可能希望这样的:

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

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

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

我怕我无法测试这个时刻,但是在过去,我相信,我不得不放弃每个选项的标签一个ID,然后我做的东西,如:

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

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

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top