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

421

У меня есть следующий <select>элемент HTML :

<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числом в качестве параметра, как выбрать соответствующую опцию в списке?

brasskazoo
источник
см. мой ответ для сравнения производительности для различных методов
Toskan

Ответы:

532

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

selectElement('leaveCode', '11')

function selectElement(id, valueToSelect) {    
    let element = document.getElementById(id);
    element.value = valueToSelect;
}
Митчел Селлерс
источник
4
Отличный ответ, это намного проще, чем перебирать варианты. И это соответствует стандартам: dev.w3.org/html5/spec/… . Если есть несовместимости браузера (конечно, есть :), мне было бы очень интересно узнать, что они есть. Это та вещь , вы обычно рассчитывать на ППК для, но он упорно отказывается , чтобы показать в моих поисках этой теме.
Philo
9
А как насчет множественного выбора? Это не работает в случае нескольких вариантов (по крайней мере, в Chrome 25).
Георгий Иванкин
2
Как указывало @ ring0, когда valueToSelect не существует, он вставляет пустую запись в Chrome. тогда как IE и firefox сохраняют последнее выбранное значение.
Картик Бозе
1
Примечание для IE: <опция> должна иметь атрибут value = 'valueToSelect'. Вы не можете использовать отображаемый текст внутри <option> .. </ option> в качестве значения toSelect
Peter Quiring
4
Если вам нужно, чтобы событие изменения было запущено, вы также должны сделать следующее: element.dispatchEvent(new Event('change'));
Патрик Джеймс
120

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

Эйнар Олафссон
источник
4
Это также может быть использовано для множественного выбора; просто передайте массив строк в функцию 'val' вместо одной строки. См .: stackoverflow.com/a/16583001/88409
Трийнко
Есть ли способ также вызвать $ ('# leftCode'). On ('change', function (), делая это?
Lieuwe
5
$ ( "# leaveCode") Вал ( "14") изменение ()..;
Лорен
29
function setSelectValue (id, val) {
    document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
Эндрю Хеджес
источник
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 элементов:

  • 1 мс
  • 58 мс
  • 612 мс

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

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

Toskan
источник
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-нетронутым и ng-недействительным классы все еще присутствуют).

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

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

а также

var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
lumi77
источник
Зачем использовать для этого jQuery, если вы уже можете делать это с Angular? При использовании самого Angular у вас нет возможности установить значение со встроенной поддержкой для запуска изменения (не знаю, я использую React, только что нашел этот пост через 5 секунд google: stackoverflow.com/questions/ 50302062 /… )? Потому что это означало бы, что вам не придется взламывать Angular с дополнительной библиотекой ± 30 КБ «только для этого» :)
SidOfc
3

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

mmattax
источник
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) разместите этот код на своей второй странице (мой случай 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 шага, и все работает отлично.

Lana
источник
1

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

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;
}
Стивен Райтон
источник
-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>';
almyz125
источник
-1

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

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

ИЛИ

$('select').prop('selectedIndex', 3); 
Makyen
источник
8
Это предполагает, что OP использует JQuery
Барри Майкл Дойл
2
@BarryMichaelDoyle, которого нет, потому что даже название вопросов заканчивается на using JavaScript.
Юлиан Онофрей
-1
function selecetElement() {
 var selectedValue = document.getElementById('leaveCode');
 selectedValue.value = "11";
}
Партха Мукерджи
источник
3
При добавлении ответа на одиннадцатилетний вопрос с шестнадцатью существующими ответами очень важно указать, к какому новому аспекту вопроса относится ваш ответ. Если вы этого не сделаете, и ваше изменение будет незначительным, оно может быть пропущено и ваш ответ будет удален как поздний дубликат. Ответы только на код можно почти всегда улучшить, добавив некоторые объяснения того, как и почему они работают.
Джейсон Аллер
-6

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

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

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

Лукас Оман
источник
3
HTMLOptionElement не имеет select()метода (он не определяет каких - либо дополнительных методов более стандартного набора на всех HTML - элементов). Однако вы можете установить для selectedсвойства значение true.
MrWhite