Avatar billede kbhadsten Nybegynder
11. november 2005 - 08:03 Der er 2 kommentarer og
1 løsning

ændre style på en anden tabelcelle end den man "klikker" på

Hej XP.dk

Jeg har lavet nedenstående script, men kan ikke få det til at virke 100%. Det jeg gerne vil er at ændre stylesheet'et på en anden tabelcelle end den man har klikket på, f.eks. via javascript. Det skal bruges på en side hvor menuen ikke reloades da der bruges frames.

Håber i forstår hvad der er jeg vil, ellers spørg

-----------------------------------------------------------------

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Untitled Document</title>
<style type="text/css">
<!--
.style1    {
background-color:#000099;
color:#FF0000;
cursor:pointer;
}
.style2    {
background-color:#000099;
color:#FF0000;
cursor:pointer;
}
-->
</style></head>

<body>
<script type="text/javascript" language="javascript">
function getID(object)
{
    var id = object.id;
    if (id == null || id == "")    {
        alert('ID har inden værdi');
    }    else    {
        alert('ID har værdien: ' + id);
        if (id == "cell_1")    {    cell_2.className = 'style2';    }  // Denne linie virker ikke :/
    }
}
</script>
<table width="200" border="0" align="center" cellpadding="0" cellspacing="5">
  <tr>
    <td id="cell_1" onClick="getID(this);">test1</td>
    </tr>
    <tr>
    <td id="cell_2" onClick="getID(this);">test2</td>
  </tr>
</table>

</body>
</html>
Avatar billede roenving Novice
11. november 2005 - 08:24 #1
Hvordan kan du se det ?-)

-- og det er iøvrigt helt tåbeligt at ændre klasse on-the-fly, ændr i stedet den property, der skal ændres !-)

-- og du ser åbenbart kun din side i een browser, for du bruger metoder, der ikke er gyldige iflg. standarderne ...


Prøv f.eks. dette:


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css">
.style1    {
  background-color:#009;
  color:#f00;
  cursor:pointer;
}
.style2{
  background-color:#009;
  color:#f00;
  cursor:default;
}
.myTable    {
  width:200px;
  border:0;
}
.myTable td{
  margin:5px;
}
</style>
<script type="text/javascript" language="javascript">
function toggleCell(object){
  if(object.id.match(/_1/)){
    var tds = document.getElementsByTagName("td");
    for(i=0;tds.length>i;i++){
      if(tds[i].className.indexOf("style2")>-1){
        tds[i].style.backgroundColor = "#009";
        tds[i].style.color = "#f00";
      }
    }
    var trg = document.getElementById(object.id.replace(/_1$/,"_2")).style;
    trg.backgroundColor = "#090";
    trg.color = "white";
  }
}
</script><title>Ændr anden celle</title>
</head>

<body>

<table class="myTable">
  <tr>
    <td class="style1" id="cell1_1" onClick="toggleCell(this);">test1</td>
    </tr>
    <tr>
    <td class="style2" id="cell1_2">test2</td>
  </tr>
  <tr>
    <td class="style1" id="cell2_1" onClick="toggleCell(this);">test1</td>
    </tr>
    <tr>
    <td class="style2" id="cell2_2">test2</td>
  </tr>
</table>

</body>
</html>
Avatar billede kbhadsten Nybegynder
24. februar 2006 - 13:33 #2
* Tråden lukkes *
Avatar billede roenving Novice
24. februar 2006 - 15:12 #3
Okaayy ?-)
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