JavaScriptを使用して選択ボックス要素の値をプログラムで設定するにはどうすればよいですか?


420

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


さまざまなメソッドのパフォーマンスの比較については、私の回答を参照してください
Toskan

回答:


532

次の関数を使用できます。

selectElement('leaveCode', '11')

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

4
すばらしい答えです。これは、オプションをループするよりもはるかに簡単です。そしてそれは標準に準拠しています:dev.w3.org/html5/spec/…。ブラウザに非互換性がある場合(もちろんあります:)私はそれらが何であるかを知りたいと非常に興味があります。それはあなたが普段ppkで頼りにしていることですが、彼は頑固にこのトピックの検索に表示されることを拒否しています。
フィロ2012年

9
そして、複数選択についてはどうですか?これは、複数のオプションがある場合には機能しないようです(少なくともChrome 25では)。
Georgii Ivankin 2013年

2
@ ring0が指摘したように、valueToSelectが存在しない場合は、Chromeに空白のエントリが挿入されます。一方、IEとfirefoxは最後に選択された値を保持します。
Karthik Bose

1
IEに関する注意:<option>にはvalue = 'valueToSelect'属性が必要です。<option> .. </ option>内の表示テキストをvalueToSelectとして使用することはできません
Peter Quiring

4
あなたが解雇されるように変更イベントが必要な場合は、実行する必要があります element.dispatchEvent(new Event('change'));
パトリック・ジェームズMcDougle

120

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関数を確認できます。


4
これは複数選択にも使用できます。単一の文字列ではなく、文字列の配列を 'val'関数に渡すだけです。参照:stackoverflow.com/a/16583001/88409
Triynko

それを行うことによって$( '#leaveCode')。on( 'change'、function()もトリガーする方法はありますか?
Lieuwe

5
$( "#leaveCode")。val( "14")。change();
Loren


16

質問には答えませんが、インデックスで選択することもできます。ここで、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
formObj.leaveCode [i] .selected = true;にするべきではありません。be formObj.options [i] .selected = true; ?
デビッドクリストファーレイノルズ

14

私はさまざまな方法を比較しました:

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秒の遅延がありました

また、テキスト値ではなく、実際の値に応じて値を設定しています。


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

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


9

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

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

そして

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

AngularJSアプリでは、必要な <select>要素がありました。

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

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

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

そして

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

Angularで既に実行できるのに、なぜjQueryを使用するのですか?Angular自体を使用する場合、変更をトリガーするための組み込みサポートで値を設定する機能はありませんか(わかりません、私はReactを使用しています、5秒後にこの投稿を見つけましたgoogle:stackoverflow.com/questions/ 50302062 /…)?これは、「ちょうどこれのために」追加の±30kbライブラリを使用してAngularをハックする必要がないことを意味するためです:)
SidOfc

3

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


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はオプションを選択したページです。ページの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つのステップで完璧に機能します。


1

要素のIDの変数を追加して、再利用可能な関数にしてみませんか?

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

1

フォームの名前が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;
    }
  }
}

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

0
function selecetElement() {
 var selectedValue = document.getElementById('leaveCode');
 selectedValue.value = "11";
}

2
16の既存の回答がある11年前の質問に回答を追加する場合、回答の対象となる質問の新しい側面を指摘することが非常に重要です。そうしないと、変更が微妙である場合、それが見落とされ、回答が遅い重複として削除される可能性があります。コードのみの回答は、ほとんどの場合、それらがどのようにそしてなぜ機能するかについての説明を追加することによって改善できます。
Jason Aller

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

-1

あなたはおそらくこれを望みます:

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

または

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

8
これはOPがJQueryを使用していることを前提としています
Barry Michael Doyle

2
@BarryMichaelDoyle、これはそうではありませんusing JavaScript。質問のタイトルもで終わるからです。
Iulian Onofrei

-6

現時点ではこれをテストすることはできないと思いますが、以前は、各オプションタグにIDを指定する必要があったと思います。

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

それがうまくいかない場合は、おそらくソリューションに近づくでしょう:P


3
HTMLOptionElementはありませんselect()(それはすべてのHTML要素の標準セット以上の追加のメソッドが定義されていない)方法を。ただし、selectedプロパティをtrueに設定できます。
MrWhite 2012年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.