• Jetzt anmelden. Es dauert nur 2 Minuten und ist kostenlos!

Aufklappbare Leiste in Frame defekt?

Status
Für weitere Antworten geschlossen.

Eistee

Neues Mitglied
Hi :-D

Ich habe mir einen Beispiel code "Aufklappbare Menü" von SELFHTML kopiert um daran zu experimentiren und so zu verstehen wie er funktionirt.

Link:
Beispiel

Jetzt zum Problem dieses "Aufklappbare Menü" funktioniert in meinem Frame nicht.
(Alles ist direct ausgeklappt und kann nicht eingeklappt werden)
Wolte jetzt mal Fragen obs halt daran liegt den wenn ich den code in ein neues Document kopiere klapt er wunderbar :roll:
(Kopiere es aus dem nicht Funktionierenden Document wo es in einem Frame ist)

Danke für eure Hilfe MfG Eistee
 
Werbung:
Die seite ist leider nicht Online

Ich kann aber hier mal mein Code reinstellen

Die seite die die 3 Frames anzeigt im Frame LINKS_MENU ist das menu drin:
HTML:
<html>
<head>
<title></title>
<meta name="author" content="Steffen">
<meta name="editor" content="html-editor phase 5">
</head>
<frameset rows="18%,*" cols="*" frameborder="1" border="10" framespacing="1">
  <frame name="OBEN_BANNER" src="Aufgabe6_Banner.html" noresize  marginwidth="3" marginheight="30">
  <frameset cols="30%,*" frameborder="1" border="10" framespacing="10">
    <frame name="LINKS_MENU" src="Aufgabe6_Menu.html">
    <frame name="HAUBT_ANZEIGE" src="Aufgabe6_Haubt_Anzeige.html" noresize marginwidth="3" marginheight="30">
  </frameset>
  <noframes>
   <body>
   </body>
  </noframes>
</frameset>
</html>

Hier ist das Menu:

HTML:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Beispiel</title>
<link rel="stylesheet" href="baum.css" media="screen, projection">
<style type="text/css">
  /* Formatierung des Baums */
  span.childs {
    cursor: pointer;
  }
  /* Klassen für das öffnen und schließen eines Knotens */
  li.treeMenu_opened ul {
    display: block;
  }
  li.treeMenu_closed ul {
    display: none;
  }
</style>
<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>
</head>
<body text="#000000" bgcolor="#FFFFFF" <body style="background-image:url(menu1.jpg)"  link="#FF0000" alink="#FF0000" vlink="#FF0000">
<body onload="treeMenu_init(document.getElementById('lebewesen'), unescape(window.name).split(',')[0]); treeMenu_init(document.getElementById('wissenschaften'), unescape(window.name).split(',')[1])" onunload="window.name = escape(treeMenu_store(document.getElementById('lebewesen')) + ',' + treeMenu_store(document.getElementById('wissenschaften')))">
  <p>
    <b>Hinweis:</b> Für die Darstellung im IE wurde hier der Einfachheit halber auf eine aufwändigere
    Gestaltung mit CSS verzichtet. Mit etwas Geduld müsste die Darstellung die in Mozilla, Opera und anderen
    Browsern zu sehen ist aber auch auf den IE übertragbar sein.
  </p>
  <h1>Lebewesen</h1>
  <ul id="lebewesen">
    <li><div><span class="childs">Tiere</span></div>
      <ul>
        <li><div><span class="childs">Säuger</span></div>
          <ul>
            <li><div><span>Hund</span></div></li>
            <li><div><span>Katze</span></div></li>
            <li class="ende"><div><span>Pferd</span></div></li>
          </ul>
        </li>
        <li class="ende"><div><span class="childs">Fische</span></div>
          <ul>
            <li><div><span>Hecht</span></div></li>
            <li class="ende"><div><span>Aal</span></div></li>
          </ul>
        </li>
      </ul>
    </li>
    <li><div><span class="childs">Pflanzen</span></div>
      <ul>
        <li><div><span>Moose</span></div></li>
        <li class="ende"><div><span>Grünalgen</span></div></li>
      </ul>
    </li>
    <li class="ende"><div><span class="childs">Pilze</span></div>
      <ul>
        <li class="ende"><div><span>Fliegenpilz</span></div></li>
      </ul>
    </li>
  </ul>
  <h1>Wissenschaften</h1>
  <ul id="wissenschaften">
    <li><div><span class="childs">Naturwissenschaften</span></div>
      <ul>
        <li><div><span>Physik</span></div></li>
        <li class="ende"><div><span>Biologie</span></div></li>
      </ul>
    </li>
    <li><div><span class="childs">Ingenieurwissenschaften</span></div>
      <ul>
        <li><div><span>Elektrotechnik</span></div></li>
        <li class="ende"><div><span>Maschinenbau</span></div></li>
      </ul>
    </li>
    <li class="ende"><div><span class="childs">Kulturwissenschaften</span></div>
      <ul>
        <li><div><span>Geschichte</span></div></li>
        <li class="ende"><div><span>Linguistik</span></div></li>
      </ul>
    </li>
  </ul>
</body>
</html>
 
Werbung:
Status
Für weitere Antworten geschlossen.
Zurück
Oben