536

次の 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、リストから適切なオプションを選択するにはどうすればよいですか?

4

17 に答える 17

670

この機能を使用できます:

selectElement('leaveCode', '11')

function selectElement(id, valueToSelect) {    
    let element = document.getElementById(id);
    element.value = valueToSelect;
}
于 2008-09-17T01:31:38.607 に答える
141

jQuery を使用している場合は、次のようにすることもできます。

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

これ<option>により、値が 14 の が選択されます。


プレーンな Javascript では、これは次の 2 つのDocument方法でも実現できます。

  • を使用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>

于 2010-12-23T15:00:15.430 に答える
30
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
于 2008-09-17T03:04:31.847 に答える
20

質問には答えませんが、インデックスで選択することもできます。ここで、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;
于 2008-09-17T01:32:10.930 に答える
16

さまざまな方法を比較しました。

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 要素の select の出力:

  • 1ミリ秒
  • 58ミリ秒
  • 612ミリ秒

Firefox 10 で。 注: このテストを行った唯一の理由は、jQuery が 2000 エントリまでのリストでパフォーマンスが非常に悪かったためです (オプション間のテキストが長かった)。val() の後、約 2 秒の遅延がありました。

同様に注意してください:テキスト値ではなく、実際の値に応じて値を設定しています。

于 2012-08-10T15:50:20.937 に答える
13
document.getElementById('leaveCode').value = '10';

これにより、選択が「年次休暇」に設定されます。

于 2008-09-17T01:34:00.067 に答える
12

上記の JavaScript/jQuery ベースのソリューションを次のように試しました。

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

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

必須の<select> 要素があった AngularJS アプリで。

AngularJS フォーム検証が起動されないため、どれも機能しません。適切なオプションが選択されていますが (フォームに表示されています)、入力は無効のままです ( ng-pristineおよびng-invalidクラスがまだ存在しています)。

AngularJS の検証を強制するには、オプションを選択した後にjQuery change()を呼び出します。

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

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
于 2015-06-01T12:38:00.713 に答える
4

必要な場合の最も簡単な方法:
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)このコードを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 ステップで完璧に機能します。

于 2011-03-18T00:53:31.280 に答える
3

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

于 2008-09-17T01:32:56.747 に答える
2

フォームの名前が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;
    }
  }
}
于 2008-09-17T03:03:01.493 に答える
2

これらの行に沿ったものでなければなりません:

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;
}
于 2008-09-17T01:35:28.083 に答える
1

要素の Id の変数を追加して、再利用可能な関数にしないのはなぜですか?

function SelectElement(selectElementId, valueToSelect)
{    
    var element = document.getElementById(selectElementId);
    element.value = valueToSelect;
}
于 2008-09-17T01:43:51.370 に答える
-2

おそらくこれが必要です:

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

また

$('select').prop('selectedIndex', 3); 
于 2016-05-25T19:07:03.747 に答える
-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>';
于 2014-01-29T05:17:07.593 に答える
-6

現時点でこれをテストすることはできませんが、過去には、各オプション タグに ID を指定する必要があったと思います。その後、次のようにしました。

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

それがうまくいかない場合は、おそらく解決策に近づくでしょう:P

于 2008-09-17T01:32:38.247 に答える