JavaScript Ausklappbare Liste soll auch ausgeklappt bleiben...

herbert101

Cadet 4th Year
Registriert
Okt. 2008
Beiträge
66
Hi,
Ich habe eine Navigation, die eine Ausklappbare Liste ist (Script von SelfHTML).
Jetzt includiere ich per php die Navigation auf den jeweiligen Seiten.
Wenn ich nun auf einen Link in einem aufgeklappten Bereich klicke wird die neue Seite geöffnet und die Navigation neu includiert, allerdings wieder komplett geschlossen und eben nicht geöffnet in dem Bereich auf dessen Unterpunkt ich gerade geklickt habe. Gibt es eine elegante Art das zu ändern? Vielleicht irgendwie in der Link-Seite einen Wert, der an die Navigation-Seite übergeben wird "hallo bleib offen"...wie ihr merkt beherrsche ich kein Javascript...

Vielen Dank Gruß herbert101

Code:
<html>
<head>
<title>Beispiel</title>
<script type="text/javascript">
  /*
   * Fügt den Listeneinträgen Eventhandler und CSS Klassen hinzu,
   * um die Menüpunkte am Anfang zu schließen.
   *
   * menu: Referenz auf die Liste.
   * data: String, der die Nummern aufgeklappter Menüpunkte enthält.
   */
  function treeMenu_init(menu, data) {
    var array = new Array(0);
    if(data != null && data != "") {
      array = data.match(/\d+/g);
    }
    var items = menu.getElementsByTagName("li");
    for(var i = 0; i < items.length; i++) {
      items[i].onclick = treeMenu_handleClick;
      if(!treeMenu_contains(treeMenu_getClasses(items[i]), "treeMenu_opened")
          && items[i].getElementsByTagName("ul").length
            + items[i].getElementsByTagName("ol").length > 0) {
        var classes = treeMenu_getClasses(items[i]);
        if(array.length > 0 && array[0] == i) {
          classes.push("treeMenu_opened")
        }
        else {
          classes.push("treeMenu_closed")
        }
        items[i].className = classes.join(" ");
        if(array.length > 0 && array[0] == i) {
          array.shift();
        }
      }
    }
  }

  /*
   * Ändert die Klasse eines angeclickten Listenelements, sodass
   * geöffnete Menüpunkte geschlossen und geschlossene geöffnet
   * werden.
   *
   * event: Das Event Objekt, dass der Browser übergibt.
   */
  function treeMenu_handleClick(event) {
    if(event == null) { //Workaround für die fehlenden DOM Eigenschaften im IE
      event = window.event;
      event.currentTarget = event.srcElement;
      while(event.currentTarget.nodeName.toLowerCase() != "li") {
        event.currentTarget = event.currentTarget.parentNode;
      }
      event.cancelBubble = true;
    }
    else {
      event.stopPropagation();
    }
    var array = treeMenu_getClasses(event.currentTarget);
    for(var i = 0; i < array.length; i++) {
      if(array[i] == "treeMenu_closed") {
        array[i] = "treeMenu_opened";
      }
      else if(array[i] == "treeMenu_opened") {
        array[i] = "treeMenu_closed"
      }
    }
    event.currentTarget.className = array.join(" ");
  }

  /*
   * Gibt alle Klassen zurück, die einem HTML-Element zugeordnet sind.
   *
   * element: Das HTML-Element
   * return: Die zugeordneten Klassen.
   */
  function treeMenu_getClasses(element) {
    if(element.className) {
      return element.className.match(/[^ \t\n\r]+/g);
    }
    else {
      return new Array(0);
    }
  }

  /*
   * Überprüft, ob ein Array ein bestimmtes Element enthält.
   *
   * array: Das Array
   * element: Das Element
   * return: true, wenn das Array das Element enthält.
   */
  function treeMenu_contains(array, element) {
    for(var i = 0; i < array.length; i++) {
      if(array[i] == element) {
        return true;
      }
    }
    return false;
  }

  /*
   * Gibt einen String zurück, indem die Nummern aller geöffneten
   * Menüpunkte stehen.
   *
   * menu: Referenz auf die Liste
   * return: Der String
   */
  function treeMenu_store(menu) {
    var result = new Array();;
    var items = menu.getElementsByTagName("li");
    for(var i = 0; i < items.length; i++) {
      if(treeMenu_contains(treeMenu_getClasses(items[i]), "treeMenu_opened")) {
        result.push(i);
      }
    }
    return result.join(" ");
  }
</script>
<style type="text/css">
  li.treeMenu_opened ul {
    display: block;
  }
  li.treeMenu_closed ul {
    display: none;
  }
</style>
<body onload="treeMenu_init(document.getElementById('menu'), '')">
<ul id="menu">
  <li>erstens
    <ul>
      <li>A</li>
      <li>B</li>
    </ul>
  </li>
  <li>zweitens
    <ul>
      <li>a</li>
      <li>b</li>
    </ul>
  </li>
</ul>
</body>
</html>
 
Hallo,
da bei der Aktion ja immer die ganze Seite neu geladen wird, ist es auch das was du prüfen musst.

Also, je nachdem wieviel Seiten du hast, mit IF oder Swicht - Abfrage und dann sagen welcher Menüpunkt hervorgehoben sein soll.

Einfach dargestellt:

If Seite = nav1.html dann nav1 = rot

Gruß

HD
 
Ja exakt das brauche ich....jetzt kenne ich nur leider die Syntax nicht von JS. Wenn mir das nun jemand vorformulieren könnte.....
 
Zuletzt bearbeitet:
FB-Deja-vu: Ohne die verwendeten PHP Skript-Klassen zu kennen, kann man das Problem nicht wirklich nachbauen. [Versuche mit "set_cookie()" ham nix gebracht] ... Jedenfalls - in Deinem Skript "kollabiert" die Navigation beim Browser-reload; bei meinem bleibt sie "expanded" [siehe Parameter "true" in "test.html"].

Also neuer Code - 5 Dateien: test.html, script.js, style.css, bzw. close.png und open.png

- zwecks Funktions-Kontrolle im selben Verzeichnis [z.B. Desktop] speichern und testen.

[1.] test.html

HTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html lang="de" xmlns="http://www.w3.org/1999/xhtml" xml:lang="de">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />

<title>test</title>

<link rel="stylesheet" type="text/css" href="style.css" />
<script type="text/javascript" src="script.js"></script>

</head>

<body onload="start_nav()">
<div id="navi">

<ul class="open" id="sidenav">

<li id="chapt01"><a class="x" onclick="toggle('chapt01',true)"><img src="open.png" 
alt="" id=
"img_chapt01" />Kapitel 1</a>

<ul id="ul_chapt01" class="open">

<li class="z"><a class="y" href="#">1.1 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">1.2 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">1.3 Inhaltsseite</a></li>
</ul>
</li>
<li id="chapt02"><a class="x" onclick="toggle('chapt02',true);"><img src="open.png"
alt="" id=
"img_chapt02" />Kapitel 2</a>

<ul id="ul_chapt02" class="open">

<li class="z"><a class="y" href="#">2.1 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">2.2 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">2.3 Inhaltsseite</a></li>

</ul>
</li>
<li id="chapt03"><a class="x" onclick="toggle('chapt03',true);"><img src="open.png"
alt="" id=
"img_chapt03" />Kapitel 3</a>

<ul id="ul_chapt03" class="open">

<li class="z"><a class="y" href="#">3.1 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">3.2 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">3.3 Inhaltsseite</a></li>

</ul>
</li>

<li id="chapt04"><a class="x" onclick="toggle('chapt04',true);"><img src="open.png"
 alt="" id=
"img_chapt04" />Kapitel 4</a>

<ul id="ul_chapt04" class="open">

<li class="z"><a class="y" href="#">4.1 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">4.2 Inhaltsseite</a></li>
<li class="z"><a class="y" href="#">4.3 Inhaltsseite</a></li>

</ul>
</li>

</ul></div>

</body></html>

[2.] script.js

Code:
function start_nav() {
for(i = 0; i < document.getElementsByTagName('ul').length; 
i++) {
if(document.getElementsByTagName('ul')[i].className == 
"open") {
id =document.getElementsByTagName('ul')[i].parentNode.id;
toggle(id, false);
}
}
if(window.name.length > 0)       
load_nav();
}
 
function toggle(id, save) {
ul = "ul_" + id;
img = "img_" + id;
ul_element = document.getElementById(ul);
img_element = document.getElementById(img);
if(ul_element) {
if(ul_element.className == 'close') {
ul_element.className = "open";
img_element.src = "open.png";
} 
else {
ul_element.className = "close";
img_element.src = "close.png";
}
}
if(save == true) save_nav();
}
 
function save_nav() {
var save = "";
for(var i = 0; i < document.getElementsByTagName('ul').length;
i++) {
if((document.getElementsByTagName('ul')[i].className == 
"open" || 
document.getElementsByTagName('ul')[i].className == 
"close") && document.getElementsByTagName('ul')[i].id != 
'sidenav') 
save = save + document.getElementsByTagName('ul')[i].id 
+ "=" + document.getElementsByTagName('ul')[i].className 
+ ",";
}
if(save.lastIndexOf(",") > 0) 
save = save.substring(0, save.lastIndexOf(","));
window.name = save;
}
 
function load_nav() {
var items = window.name.split(",");
if(items.length > 0) {
for(var i = 0; i < items.length; i++) {        
id_value = items[i].split("=");         
if(id_value.length == 2) {
id = id_value[0];  
value = id_value[1];
document.getElementById(id).className = value;
img = "img_" + id.substring(3, id.length);
img_element = document.getElementById(img);
if(value == "close")
img_element.src = "close.png";  
else
img_element.src = "open.png";
}
}
}
}

[3.] style.css

Code:
body   {font-family:"courier new", sans-serif; color:#444;}
#navi   {position:absolute; top:15px; left:15px; overflow:hidden;}

ul   {list-style-type:none;}
ul.close, ul.open   {font-size:16.9px; line-height:25px;}
ul.close   {display:none;}
ul.open   {display:block;}

li.z   {margin-left:-39px; list-style-type:none;}
  
a.x   {cursor:pointer;}  
a.y   {color:#444; text-decoration:none;}
a.y:hover   {text-decoration:underline;}

[4.] + [5.] Zwei Mini-pngs im Anhang

[+] = close.png [-] = open.png
[Firefoxfenster verkleinern - Grafiken mit gedrückter Maustaste rausziehen und umbenennen]


GF
 
Zuletzt bearbeitet:
Zurück
Oben