web-dev-qa-db-ja.com

JavaScriptを使用してプログラムでselect box要素の値を設定する方法を教えてください。

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

338
brasskazoo
SelectElement("leaveCode", valueToSelect)

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

あなたがjQueryを使っているならば、あなたもこれをすることができます:

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

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


普通の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>
96
Einar Ólafsson
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
28
Andrew Hedges

質問には答えませんが、インデックスで選択することもできます。ここで、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;
14
Chase Seibert

私は異なる方法を比較しました:

JSまたはjQueryを使用してselectの値を設定する方法に関するさまざまな方法の比較

コード:

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

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

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

選択は「年次休暇」に設定する必要があります。

9
William

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

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

そして

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

angularJSアプリケーションでは、 required <select>要素がありました。

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

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

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

そして

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

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

あなたがする必要がある場合は最も簡単な方法:
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のページに?オプション= 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ステップで、完璧に機能します。

3
Lana

これらの線に沿って何かあるべきです:

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;
}
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
Milan Babuškov

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

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

あなたはおそらくこれが欲しい:

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

OR

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