it-swarm-pt.tech

Como definir programaticamente o valor de um elemento da caixa de seleção usando JavaScript?

Eu tenho o seguinte elemento 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>

Usando uma função JavaScript com o número leaveCode como parâmetro, como seleciono a opção apropriada na lista?

343
brasskazoo
SelectElement("leaveCode", valueToSelect)

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

Se você estiver usando o jQuery, você também pode fazer isso:

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

Isto irá selecionar o <option> com o valor de 14.


Com JavaScript simples, isso também pode ser obtido com dois Document métodos :

  • Com document.querySelector , você pode selecionar um elemento baseado em um seletor CSS:

    document.querySelector('#leaveCode').value = '14'
    
  • Usando a abordagem mais estabelecida com document.getElementById() , que, como o nome da função implica, permite que você selecione um elemento baseado em seu id:

    document.getElementById('leaveCode').value = '14'
    

Você pode executar o código abaixo recortado para ver esses métodos e a função jQuery em ação:

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

Não respondendo a pergunta, mas você também pode selecionar por índice, onde i é o índice do item que você deseja selecionar:

var formObj = document.getElementById('myForm');
formObj.leaveCode[i].selected = true;

Você também pode percorrer os itens para selecionar por valor de exibição com um loop:

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

Eu comparei os diferentes métodos:

Comparação das diferentes formas de como definir um valor de uma seleção com JS ou jQuery

código:

$(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);


});

Saída em um select com ~ 4000 elementos:

1 ms

58 ms

612 ms

Com o Firefox 10. Nota: A única razão pela qual fiz este teste, foi porque o jQuery teve um desempenho muito ruim em nossa lista, com ~ 2000 entradas (eles tinham textos mais longos entre as opções). Nós tivemos aproximadamente 2 s de atraso depois de um val ()

Observe também: estou definindo valor dependendo do valor real, não do valor do texto

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

Isso deve definir a seleção para "licença anual"

9
William

Eu tentei as soluções baseadas em JavaScript/jQuery acima, como:

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

e

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

em um aplicativo AngularJS, onde havia um elemento obrigatório <select>.

Nenhum deles funciona, porque a validação do formulário AngularJS não é disparada. Embora a opção correta tenha sido selecionada (e exibida no formulário), a entrada permaneceu inválida ( ng-pristine e ng-invalid classes ainda presentes).

Para forçar a validação do AngularJS, chame jQuery change () depois de selecionar uma opção:

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

e

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

A maneira mais fácil se você precisa:
1) Clique em um botão que define a opção de seleção
2) Vá para outra página, onde a opção de seleção é
3) Ter esse valor de opção selecionado em outra página

1) seus links de botão (digamos, na página inicial)

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

(onde contact.php é a sua página com opções de seleção. Note que a URL da página tem? option = 1 ou 2)

2) colocar este código na sua segunda página (meu caso contact.php)

<?
if (isset($_GET['option']) && $_GET['option'] != "") {
$pg = $_GET['option'];              
} ?>

) faz o valor da opção selecionado, dependendo do botão clicado

<select>
<option value="Sales" <? if ($pg == '1') { echo "selected"; } ?> >Sales</option>
<option value="IT" <? if ($pg == '2') { echo "selected"; } ?> >IT</option>
</select>

.. e assim por diante.
Portanto, esta é uma maneira fácil de passar o valor para outra página (com a lista de opções de seleção) por meio de GET in url. Sem formulários, sem IDs .. apenas 3 passos e funciona perfeito.

3
Lana

Deve ser algo ao longo destas linhas:

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
Stephen Wrighton

Suponha que seu formulário tenha o nome 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

Por que não adicionar uma variável para o Id do elemento e torná-la uma função reutilizável?

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

Você provavelmente quer isso:

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

OR

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