Como defino programaticamente o valor de um elemento de caixa de seleção usando JavaScript?
-
09-06-2019 - |
Pergunta
Eu tenho o seguinte HTML <select>
elemento:
<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 leaveCode
número como parâmetro, como seleciono a opção apropriada na lista?
Solução
SelectElement("leaveCode", valueToSelect)
function SelectElement(id, valueToSelect)
{
var element = document.getElementById(id);
element.value = valueToSelect;
}
Outras dicas
Se você estiver usando jQuery, você também pode fazer isso:
$('#leaveCode').val('14');
Isso selecionará o <option>
com o valor de 14.
Com Javascript simples, isso também pode ser conseguido com dois Document
métodos:
Com
document.querySelector
, você pode selecionar um elemento com base em um seletor CSS:document.querySelector('#leaveCode').value = '14'
Usando a abordagem mais estabelecida com
document.getElementById()
, que, como o nome da função indica, permitirá que você selecione um elemento com base em seuid
:document.getElementById('leaveCode').value = '14'
Você pode executar o código abaixo cortado 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>
function setSelectValue (id, val) {
document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
Não respondendo a pergunta, mas você também pode selecionar por índice, onde i é o índice do item que 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;
Comparei os diferentes métodos:
Comparação das diferentes maneiras de definir um valor de um select 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 uma seleção com aproximadamente 4.000 elementos:
1 ms
58ms
612ms
Com Firefox 10.Observação:A única razão pela qual fiz esse teste foi porque o jQuery teve um desempenho muito ruim em nossa lista com cerca de 2.000 entradas (eles tinham textos mais longos entre as opções).Tivemos um atraso de aproximadamente 2 s após um val()
Observe também:Estou definindo o valor dependendo do valor real, não do valor do texto
document.getElementById('leaveCode').value = '10';
Isso deve definir a seleção para "Licença Anual"
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 obrigatório elemento <selecionar>.
Nenhum deles funciona, pois a validação do formulário AngularJS não é acionada.Embora a opção correta tenha sido selecionada (e seja exibida no formulário), a entrada permaneceu inválida (ng-imaculado e ng-inválido turmas ainda presentes).
Para forçar a validação do AngularJS, chame jQuery mudar() depois de selecionar uma opção:
$("#leaveCode").val("14").change();
e
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
function foo(value)
{
var e = document.getElementById('leaveCode');
if(e) e.value = value;
}
A maneira mais fácil se você precisar:
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 está
3) Selecione o valor dessa opção em outra página
1) links de seus botões (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 contato.php é a sua página com opções selecionadas.Observe que o URL da página tem ?option=1 ou 2)
2) coloque esse código na sua segunda página (meu caso contato.php)
<?
if (isset($_GET['option']) && $_GET['option'] != "") {
$pg = $_GET['option'];
} ?>
3) selecione o valor da opção, 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 lista de opções selecionadas) através de GET na url.Sem formulários, sem IDs.apenas 3 passos e funciona perfeitamente.
Por que não adicionar uma variável para o Id do elemento e torná-lo uma função reutilizável?
function SelectElement(selectElementId, valueToSelect)
{
var element = document.getElementById(selectElementId);
element.value = valueToSelect;
}
Suponha que seu formulário tenha o nome formulário 1:
function selectValue(val)
{
var lc = document.form1.leaveCode;
for (i=0; i<lc.length; i++)
{
if (lc.options[i].value == val)
{
lc.selectedIndex = i;
return;
}
}
}
Deve ser algo nesse sentido:
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;
}
Você provavelmente quer isso:
$("._statusDDL").val('2');
OU
$('select').prop('selectedIndex', 3);
Se estiver usando PHP, você pode tentar algo assim:
$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>';
Receio não poder testar isso no momento, mas no passado, acredito que tive que dar um ID a cada tag de opção e então fiz algo como:
document.getElementById("optionID").select();
Se isso não funcionar, talvez você fique mais perto de uma solução: P