Avatar billede radion Nybegynder
08. oktober 2006 - 18:05 Der er 5 kommentarer og
1 løsning

vis / skjul lag afhængig af værdi i dropdown

Hej eksperter

jeg har næsten brik forstand på javascript, så lidt hjælp vil være kærkomment.

jeg har en dropdown
<select name="type"><option value="1">hjemme</option><option value="2">Syg</option></select>

og nogle rows i en tabel
<tr id='2'><td>jeg er syg</td></tr>
<tr id='1'><td>Jeg er hjemme</td></tr>

hvis man vælger "hjemme"(value=1) i dropdown menuen skal tabelrækken med id=1 vises, og tabelrækken med id=2 skjules.

og omvendt hvis man vælger "syg"(value=2) i dropdown menuen skal tabelrækken med id=2 vises, og tabelrækken med id=1 skjules.


hvordan krængles det med javascript?
jeg tænker umiddelbart en onchange i <select> der kalder en javascriptfunktion.. men, hvordan skal funktionen se ud?
Avatar billede jannek_ek Nybegynder
08. oktober 2006 - 19:26 #1
der skal bare bruges et simpelt java script:

<html>
<head>
<script type="text/javascript">
  var old = 1;
  function skift(nr){
  document.getElementById(old).style.display='none'
  document.getElementById(nr).style.display='table-row'
  old = nr;
  }
</script>
</head>
<body>
<form>
  <select onChange="skift(this.value)">
  <option value="1">nr 1</option>
  <option value="2">nr 2</option>
  </select>
</form>
<table>
  <tr id="1" style="display: table-row ">
  <td>
    tekst 1
  </td>
  </tr>
  <tr id="2" style="display: none ">
  <td>
    tekst 2
  </td>
  </tr>
</table>
</body>
</html>

den række der skal vises fra starten af skal indeholde display: table-row resten skal hedde display: none
Avatar billede jannek_ek Nybegynder
08. oktober 2006 - 19:40 #2
hov beklager lavede en fejl
internet explore kan ikke forstå display:table-row så der skal ikke stå noget der:

<html>
<head>
<script type="text/javascript">
  var old = 1;
  function skift(nr){
  document.getElementById(old).style.display='none'
  document.getElementById(nr).style.display=''
  old = nr;
  }
</script>
</head>
<body>
<form>
  <select onChange="skift(this.value)">
  <option value="1">nr 1</option>
  <option value="2">nr 2</option>
  </select>
</form>
<table>
  <tr id="1" style="display: ">
  <td>
    tekst 1
  </td>
  </tr>
  <tr id="2" style="display: none ">
  <td>
    tekst 2
  </td>
  </tr>
</table>
</body>
</html>
Avatar billede radion Nybegynder
09. oktober 2006 - 09:55 #3
er det muligt at få en if else ind i scriptet.. det bunder i at min selectbox er lidt mere end bare de 2 muligheder jeg har stillet op, og ved den ene option er der 2 <tr> der skal vises
Avatar billede radion Nybegynder
09. oktober 2006 - 09:56 #4
og under nogle af mine options er der slet ikke noget der skal vises...
Avatar billede radion Nybegynder
09. oktober 2006 - 10:03 #5
Har luret det :) tak for  hjælpen
Avatar billede jannek_ek Nybegynder
09. oktober 2006 - 16:52 #6
det var så lidt og tak for points :P
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