Am urmatoarele HTML `<selectați> element:
<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>
Folosind o funcție JavaScript cu `leaveCode numărul ca un parametru, cum fac selectați opțiunea corespunzătoare din lista?
Puteți utiliza această funcție:
``js selectElement('leaveCode', '11')
funcția selectElement(id, valueToSelect) { lasa element = document.getElementById(id); element.valoare = valueToSelect; } ``
Dacă utilizați jQuery, puteți, de asemenea, face acest lucru:
$('#leaveCode').val('14');
Aceasta va selecta `<opțiune> cu valoare de 14.
Cu simple Javascript, acest lucru poate fi, de asemenea, realizat cu două "Document" metode:
document.querySelector
, puteți selecta un element de baza de pe un selector CSS:document.querySelector('#leaveCode').valoarea = '14'
document.getElementById()
, care va, ca numele funcției implică, să selectați un element pe baza "id":document.getElementById('leaveCode').valoarea = '14'
Puteți rula codul de mai jos indepartate pentru a vedea aceste metode și funcția jQuery în acțiune:
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>
Nu răspunde la întrebare, dar puteți selecta, de asemenea, de index, unde i este indicele elementului pe care doriți să selectați:
var formObj = document.getElementById('myForm');
formObj.leaveCode[i].selected = true;
Puteți, de asemenea, bucla prin elemente pentru a selecta prin afișare valoare cu o buclă:
for (var i = 0, len < formObj.leaveCode.length; i < len; i++)
if (formObj.leaveCode[i].value == 'xxx') formObj.leaveCode[i].selected = true;
Am comparat diferite metode:
[Comparație între diferite modalități cu privire la modul pentru a seta o valoare de o selectați cu JS sau jQuery][1]
cod:
$(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);
});
De ieșire de pe o selectați cu ~4000 de elemente:
1 ms
58 ms
612 ms
Cu Firefox 10. Notă: singurul motiv pentru care am făcut acest test, a fost pentru jQuery efectuate super prost pe lista noastră cu ~2000 de intrări (au avut texte mai lungi dintre opțiuni). Am avut aproximativ 2 s întârziere, după un val()
Notă la fel de bine: eu sunt de stabilire a valorii în funcție de valoarea reală, nu valoarea text
Am încercat de mai sus JavaScript/jQuery pe bază de soluții, cum ar fi:
$("#leaveCode").val("14");
și
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
într-un AngularJS app, în cazul în care nu a fost un necesare <selectați> element.
Niciunul dintre ei nu funcționează, pentru că AngularJS formă de validare nu este concediat. Deși dreptul de opțiune a fost selectată (și este afișat în formă), intrare rămas invalid (ng-curat și ng-invalid clase încă prezente).
Pentru a forța AngularJS de validare, apel jQuery modifica() după selectarea unei opțiuni:
$("#leaveCode").val("14").change();
și
var leaveCode = document.querySelector('#leaveCode');
leaveCode[i].selected = true;
$(leaveCode).change();
Cel mai simplu mod, dacă aveți nevoie să:
1) butonul de link-uri (de exemplu, pe pagina de start)
<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>
(unde contact.php este pagina dvs. cu selectați opțiuni. Notă pagina url ?opțiunea=1 sau 2)
2) pune acest cod pe pagina a doua (cazul meu contact.php)
<?
if (isset($_GET['option']) && $_GET['option'] != "") {
$pg = $_GET['option'];
} ?>
3) asigurați-valoarea opțiunii selectate, în funcție de butonul apasat
<select>
<option value="Sales" <? if ($pg == '1') { echo "selected"; } ?> >Sales</option>
<option value="IT" <? if ($pg == '2') { echo "selected"; } ?> >IT</option>
</select>
.. și așa mai departe.
Deci, aceasta este o modalitate ușoară de a trece de la o valoare la alta pagina (cu selectați opțiunea list) prin IA în url-ul. Nici forme, nici Id-uri.. doar 3 pași și funcționează perfect.
Ar trebui să fie ceva de-a lungul acestor linii:
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;
}
De ce nu-l adăugați o variabilă pentru elementul's Id-ul și să-l un reutilizabile funcție?
function SelectElement(selectElementId, valueToSelect)
{
var element = document.getElementById(selectElementId);
element.value = valueToSelect;
}
Dacă utilizați PHP ai putea incerca ceva de genul asta:
$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>';
Am'm'm în imposibilitatea de a testa acest lucru în momentul de față, dar în trecut, cred că am avut de a da fiecare opțiune tag un ID, si apoi am facut ceva de genul:
document.getElementById("optionID").select();
Dacă asta nu't de lucru, poate l'll a obține mai aproape de o soluție :P