it-swarm.it

Come faccio a impostare in modo programmatico il valore di un elemento casella di selezione utilizzando JavaScript?

Ho il seguente 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>

Utilizzando una funzione JavaScript con il numero leaveCode come parametro, come selezionare l'opzione appropriata nell'elenco?

338
brasskazoo
SelectElement("leaveCode", valueToSelect)

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

Se usi jQuery puoi anche farlo:

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

Questo selezionerà <option> con il valore di 14.


Con Javascript semplice, questo può essere ottenuto anche con due Document metodi :

  • Con document.querySelector , puoi selezionare un elemento basato su un selettore CSS:

    document.querySelector('#leaveCode').value = '14'
    
  • Usando l'approccio più consolidato con document.getElementById() , questo, come dice il nome della funzione, ti permette di selezionare un elemento basato sul suo id:

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

Puoi eseguire il seguente codice snipped per vedere questi metodi e la funzione jQuery in azione:

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

Non rispondere alla domanda, ma puoi anche selezionare per indice, dove i è l'indice dell'articolo che desideri selezionare:

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

Puoi anche scorrere tra gli elementi per selezionare per valore di visualizzazione con un ciclo:

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

Ho confrontato i diversi metodi:

Confronto dei diversi modi su come impostare un valore di una selezione con JS o jQuery

codice:

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


});

Uscita su una selezione con ~ 4000 elementi:

1 ms

58 ms

612 ms

Con Firefox 10. Nota: l'unico motivo per cui ho fatto questo test, è stato il fatto che jQuery si è comportato in modo molto scadente nella nostra lista con ~ 2000 voci (avevano testi più lunghi tra le opzioni). Abbiamo avuto circa 2 s di ritardo dopo un val ()

Nota anche: sto impostando il valore in base al valore reale, non al valore del testo

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

Questo dovrebbe impostare la selezione su "Congedo annuale"

9
William

Ho provato le soluzioni JavaScript/jQuery di cui sopra, come ad esempio:

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

e

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

in un'app AngularJS, dove c'era un elemento required <select>.

Nessuno di questi funziona, perché la convalida del modulo AngularJS non viene attivata. Sebbene sia stata selezionata l'opzione giusta (e visualizzata nel modulo), l'input è rimasto invalido ( ng-pristine e ng-invalid classes ancora presenti).

Per forzare la convalida di AngularJS, chiama jQuery change () dopo aver selezionato un'opzione:

$("#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

Il modo più semplice se hai bisogno di:
1) Fare clic su un pulsante che definisce l'opzione di selezione
2) Vai a un'altra pagina, dove è selezionata l'opzione
3) Avere il valore di questa opzione selezionato su un'altra pagina

1) i link dei pulsanti (ad esempio, nella home page)

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

(dove contact.php è la tua pagina con le opzioni selezionate Nota l'url della pagina ha? option = 1 o 2)

2) inserisci questo codice nella tua seconda pagina (il mio caso contact.php )

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

3) rende selezionato il valore dell'opzione, a seconda del pulsante su cui si fa clic

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

.. e così via.
Quindi questo è un modo semplice per passare il valore a un'altra pagina (con l'elenco delle opzioni selezionate) tramite GET in url. Nessun modulo, nessun ID .. solo 3 passaggi e funziona perfettamente.

3
Lana

Dovrebbe essere qualcosa in questo senso:

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

Supponiamo che il tuo modulo sia denominato 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

Perché non aggiungere una variabile per l'ID dell'elemento e renderla una funzione riutilizzabile?

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

Molto probabilmente lo vuoi:

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

OR

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