Avatar billede jakobsen Nybegynder
18. marts 2006 - 11:04 Der er 7 kommentarer og
1 løsning

select box 2 efter select box 1

Hej

Jeg har 2 select boxe,den første med tallene fra 1 -> 9
nr. 2 skal så være udfra den første dvs.

hvis man vælger 5 i den første må man max kunne vælge
1->5 i nr 2, hvis man vælger 7 så max 1 -> 7.

Findes der en smart måde med js at gøre det?
Avatar billede stiness Nybegynder
18. marts 2006 - 11:28 #1
Hmm.. mon følgende kan bruges til noget?:} -Stine

<HTML>
<HEAD>
<SCRIPT>
function js_select() {
    // First select:
    var selectedVal1 = -1;
    try {
    selectedVal1 = document.getElementById("SEL1").value;
    } catch (error) { }
    var html = "<SELECT ID=\"SEL1\" ONCHANGE=\"java script: js_select();\">";
    for (var i = 1; i <= 9; i++) {
    html += "<OPTION VALUE=\"" + i + "\" " + ((i == selectedVal1) ? "SELECTED" : "") + ">" + i + "</OPTION>";
    }
    html += "</SELECT>&nbsp;";
    // Second select:
    var selectedVal2 = -1;
    try {
    selectedVal2 = document.getElementById("SEL2").value;
    } catch (error) { }
    html += "<SELECT ID=\"SEL2\">";
    for (var i = 1; (i <= 9) && ((selectedVal1 == -1) || (i <= selectedVal1)); i++) {
    html += "<OPTION  VALUE=\"" + i + "\" " + ((i == selectedVal2) ? "SELECTED" : "") + ">" + i + "</OPTION>";
    }
    html += "</SELECT>";   
    document.getElementById("SEL_DIV").innerHTML = html;
}
</SCRIPT>
</HEAD>
<BODY ONLOAD="java script: js_select();">
<DIV ID="SEL_DIV"></DIV>
</BODY>
</HTML>
Avatar billede jakobsen Nybegynder
18. marts 2006 - 11:52 #2
har du et eks. hvor <select><option> osv er med ?
Avatar billede stiness Nybegynder
18. marts 2006 - 11:54 #3
Eksempel? Hvis du putter koden inde i en index.html og åbner den i et browser, har du et eksempel:) Hvad vil du gerne have det sat ind i da?
Avatar billede stiness Nybegynder
18. marts 2006 - 11:58 #4
"ind i" og "en browser" sæføli>) Ku bare ikke lige holde det ud;)
Avatar billede stiness Nybegynder
18. marts 2006 - 12:44 #5
Gav du op?:)
Avatar billede roenving Novice
20. marts 2006 - 01:27 #6
Hrm, det kan da laves adskilligt lettere:

<script type="text/javascript">
function updateSel(sel){
  var sel2 = document.getElementById("sel2");
  sel2.length = 0;
  if(sel.selectedIndex == 0)
    sel2.options[0] = new Option("Vælg i den første selectboks");
  else
    for(i=1;sel.value>=i;i++)
      sel2.options[sel2.length] = new Option(i,i);
  }
}
</script>

<select id="sel1" onchange="updateSel(this);">
  <option>-- Vælg antal --</option>
  <option value="1">1</option>
  <option value="2">2</option>
  <option value="3">3</option>
  <option value="4">4</option>
  <option value="5">5</option>
  <option value="6">6</option>
  <option value="7">7</option>
  <option value="8">8</option>
  <option value="9">9</option>
</select><br>
<select id="sel2">
  <option>Vælg i den første selectboks</option>
</select>

-- og det undgår i øvrigt alle potentielle fremtidsproblemer med innerHTML !-)
Avatar billede jakobsen Nybegynder
20. marts 2006 - 15:02 #7
roenving: sådan noget som dit søger jeg.

men har du setet det? det virker ik her? javascript fejler når
den skal update..
Avatar billede roenving Novice
20. marts 2006 - 15:49 #8
Jeg har kun testet det umiddelbart i editoren, for der er intet, som ikke burde virke i alle nyere browsere (men der hører f.eks. IE/mac vist heller ikke til !-)

-- argh, jeg havde glemt at konsekvensrette helt igennem, for jeg fjernede en stribe overflødige tuborger ...

Bare fjern den sidste før </script>, så kører det !o]
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester