Как программно установить значение элемента select box, используя JavaScript? - PullRequest
342 голосов
/ 17 сентября 2008

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

Ответы [ 15 ]

1 голос
/ 17 сентября 2008

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

function SelectElement(selectElementId, valueToSelect)
{    
    var element = document.getElementById(selectElementId);
    element.value = valueToSelect;
}
1 голос
/ 17 сентября 2008

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

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 голосов
/ 25 мая 2016

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

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

OR

$('select').prop('selectedIndex', 3); 
0 голосов
/ 29 января 2014

Если вы используете 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>';
0 голосов
/ 17 сентября 2008

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

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

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...