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

dhtml in frames

Status
Für weitere Antworten geschlossen.

veni vidi vici

Neues Mitglied
ich wollte zu ner hp eine Navigationsleiste zum aufklappen erstellen, also mit 2. und 3. menüs usw.
allerdings wenn ichs in mein frame für die navigationsleiste reinhau und dann ein link anklicke kommt der größte wirrwar raus, bei ff und ie.
nein, ich möchte das ganze so schlicht mit html haben, auser es gibt nochmal eine möglichkeit mit html die nicht aufwändig ist.
hier mal der code:

Code:
[LEFT]<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>Index
    <ul>
      <li><a href="index.html">Index</a></li>
      <li>B</li>  
    </ul>
  </li>
  <li>Ergebnisse
    <ul>
      <li><a href="ergebnisse.html" target="blank">2005</a></li>
      <li>2006</li>
    </ul>
  </li>
  <li>Volkslauf
      <ul>
      <li>2005</li>
      <li>2006</li>
      </ul>
  </li>
   <li>Lauftreff
      <ul>
      <li>Dienstags</li>
      <li>Freitags</li>
      <li>Samstags</li>
      </ul>
  </li>
    <li>Laufkurse
      <ul>
      <li>ll</li>
      <li>22</li>
      </ul>
  </li>
    <li>usw.
      <ul>
      <li>...</li>
      <li>!!!</li>
      </ul>
  </li>
</ul>
</body>
</html>
[/LEFT]
 
Wieso machst du es dir so kompliziert?

HTML
Code:
<ul id="menu">
  <li onmouseover="document.getElementById('listpunkt1').style.display='block';" onmouseout="document.getElementById('listpunkt1').style.display='none';">Index
    <ul id="listpunkt1">
      <li><a href="index.html">Index</a></li>
      <li>B</li>  
    </ul>
  </li>
</ul>

CSS:
Code:
#menu ul { display: none; }

Ganz grob :)
 
thx schonmal dafür, aber ich verstehe nicht warum der link im frame geöffnet wird und nicht im ganzen fenster? gibt es da nicht auchsowas wie target="blank" nur dass es für das fenster gilt und nicht für den frame?
 
Jetzt verstehe ich wiederum nicht wie du von diesem Klappmenü auf frames kommst. Vermutlich suchst du nach

Code:
target="_top"

? Damit werden Frames aufgelöst. Oder

Code:
target="_self"

- lädt die angegebene Seite im selben Frame.
 
Status
Für weitere Antworten geschlossen.

Neueste Beiträge

Zurück
Oben