Как программно установить значение элемента box select с помощью JavaScript?

У меня есть следующий элемент 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 в качестве параметра, как выбрать подходящий параметр в списке?

Ответ 1

Вы можете использовать эту функцию:

selectElement('leaveCode', '11')

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

Ответ 2

Если вы используете jQuery, вы также можете сделать это:

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

Это выберет <option> со значением 14.


В обычном Javascript этого также можно достичь с помощью двух 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>

Ответ 3

function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);

Ответ 4

Не отвечая на вопрос, но вы также можете выбрать по индексу, где я - индекс элемента, который вы хотите выбрать:

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;

Ответ 5

Я сравнивал различные методы:

Сравнение различных способов установки значения выбора с помощью 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 элементами:

1 мс

58 мс

612 мс

С Firefox 10. Примечание. Единственная причина, по которой я сделал этот тест, заключалась в том, что jQuery очень плохо выполнялся в нашем списке с ~ 2000 записей (у них были более длинные тексты между опциями). У нас была грубая 2-секундная задержка после val()

Обратите также внимание: я устанавливаю значение в зависимости от реального значения, а не текстового значения

Ответ 6

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

Для этого нужно выбрать "Годовой отпуск"

Ответ 7

Я пробовал вышеупомянутые решения на основе JavaScript/jQuery, такие как:

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

а также

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

в приложении AngularJS, где был требуемый элемент <select>.

Ни одна из них не работает, поскольку валидация формы AngularJS не запускается. Хотя была выбрана правильная опция (и отображается в форме), вход остался недействительным (ng-нетронутые и ng-недопустимые классы все еще присутствуют).

Чтобы принудительно выполнить проверку по AngularJS, вызовите jQuery change() после выбора опции:

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

а также

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

Ответ 8


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

Ответ 9

Самый простой способ, если вам нужно:
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) поместите этот код на свою вторую страницу (мой случай 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>

.. и т.д.
Таким образом, это простой способ передать значение на другую страницу (с помощью списка опций) через GET в URL-адресе. Без форм, без идентификаторов.. всего 3 шага, и он отлично работает.

Ответ 10

Должно быть что-то в этом роде:

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

Ответ 11

Почему бы не добавить переменную для идентификатора элемента и сделать ее многоразовой функцией?

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

Ответ 12

Предположим, что ваша форма имеет имя 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;
    }
  }
}

Ответ 13

Скорее всего, вы хотите это:

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

ИЛИ ЖЕ

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

Ответ 14

Использование JQuery:

$('leaveCode').prop('selectedIndex', 10);

Ответ 15

Если вы используете 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>';

Ответ 16

Я боюсь, что я не могу проверить это на данный момент, но в прошлом я полагал, что должен был предоставить каждому тегу опции ID, а затем я сделал что-то вроде:

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

Если это не сработает, возможно, это приблизит вас к решению: P