Come posso impostare a livello di codice il valore di un elemento della casella di selezione utilizzando JavaScript?
-
09-06-2019 - |
Domanda
Ho il seguente 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>
Utilizzando una funzione JavaScript con il file leaveCode
numero come parametro, come faccio a selezionare l'opzione appropriata nell'elenco?
Soluzione
SelectElement("leaveCode", valueToSelect)
function SelectElement(id, valueToSelect)
{
var element = document.getElementById(id);
element.value = valueToSelect;
}
Altri suggerimenti
Se usi jQuery puoi anche fare questo:
$('#leaveCode').val('14');
Questo selezionerà il <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 in base a un selettore CSS:document.querySelector('#leaveCode').value = '14'
Utilizzando l'approccio più consolidato con
document.getElementById()
, che, come suggerisce il nome della funzione, ti consentirà di selezionare un elemento in base al suoid
:document.getElementById('leaveCode').value = '14'
Puoi eseguire il codice seguente ritagliato 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>
function setSelectValue (id, val) {
document.getElementById(id).value = val;
}
setSelectValue('leaveCode', 14);
Non rispondo 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 gli elementi da selezionare in base al valore visualizzato 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;
Ho confrontato i diversi metodi:
Confronto tra i 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);
});
Output su una selezione con ~ 4000 elementi:
1 ms
58 ms
612 ms
Con Firefox 10.Nota:L'unico motivo per cui ho eseguito questo test è perché jQuery ha funzionato molto male nel nostro elenco con circa 2000 voci (avevano testi più lunghi tra le opzioni).Abbiamo avuto un ritardo di circa 2 s dopo un val()
Nota anche:Sto impostando il valore in base al valore reale, non al valore del testo
document.getElementById('leaveCode').value = '10';
Ciò dovrebbe impostare la selezione su "Ferie annuali"
Ho provato le soluzioni basate su JavaScript/jQuery di cui sopra, come:
$("#leaveCode").val("14");
E
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
in un'app AngularJS, dove era presente un file necessario <seleziona> elemento.
Nessuno di questi funziona, perché la convalida del modulo AngularJS non viene attivata.Sebbene sia stata selezionata l'opzione corretta (e sia visualizzata nel modulo), l'input è rimasto non valido (ng-incontaminato E ng-non valido classi ancora presenti).
Per forzare la convalida AngularJS, chiama jQuery modifica() dopo aver selezionato un'opzione:
$("#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;
}
Il modo più semplice se hai bisogno di:
1) Fare clic su un pulsante che definisce l'opzione di selezione
2) Vai ad un'altra pagina, dove si trova l'opzione Seleziona
3) Avere il valore dell'opzione selezionato su un'altra pagina
1) i collegamenti 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 contatto.php è la tua pagina con le opzioni selezionate.Nota che l'URL della pagina ha ?option=1 o 2)
2) inserisci questo codice nella tua seconda pagina (il mio caso contatto.php)
<?
if (isset($_GET['option']) && $_GET['option'] != "") {
$pg = $_GET['option'];
} ?>
3) rendere selezionato il valore dell'opzione, a seconda del pulsante cliccato
<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 di opzioni selezionate) tramite GET nell'URL.Nessun modulo, nessun documento d'identità..bastano 3 passaggi e funziona perfettamente.
Perché non aggiungere una variabile per l'ID dell'elemento e renderlo una funzione riutilizzabile?
function SelectElement(selectElementId, valueToSelect)
{
var element = document.getElementById(selectElementId);
element.value = valueToSelect;
}
Supponiamo che il tuo modulo sia denominato modulo1:
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;
}
}
}
Dovrebbe essere qualcosa del genere:
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;
}
Molto probabilmente vorrai questo:
$("._statusDDL").val('2');
O
$('select').prop('selectedIndex', 3);
Se usi PHP potresti provare qualcosa del genere:
$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>';
Temo di non poterlo testare al momento, ma in passato credo di dover dare a ciascun tag di opzione un ID e poi ho fatto qualcosa del tipo:
document.getElementById("optionID").select();
Se non funziona, forse ti avvicinerà a una soluzione: P