ilja: javascript problem

Beitrag lesen

hallo,

ich habe ein java script auklabbares menue von einem DHTML script. hier: http://aktuell.de.selfhtml.org/tippstricks/dhtml/treemenu/index.htm

ich wollte es in meiner XSL datei einsetzen, dass es in XML datei ausgibt! aber leider kommen da java script fehler! warum? was ist da falsch?

meine XSL datei:

<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
 <xsl:template match="/">
  <HTML>
   <HEAD>
    <TITLE>test</TITLE>
    <script type="text/javascript"><![CDATA[

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();
        }
      }
    }
  }

function treeMenu_handleClick(event) {
    if(event == null) { //Workaround f� 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(" ");
  }

function treeMenu_getClasses(element) {
    if(element.className) {
      return element.className.match(/[^ \t\n\r]+/g);
    }
    else {
      return new Array(0);
    }
  }

function treeMenu_contains(array, element) {
    for(var i = 0; i < array.length; i++) {
      if(array[i] == element) {
        return true;
      }
    }
    return false;
  }

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>
   </HEAD>
   <BODY onload="treeMenu_init(document.getElementById('menu'), '')">
    <script language="JavaScript"><![CDATA[ document.write('............ test ............'); ]]></script>
    <hr/>
    <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>
 </xsl:template>
</xsl:stylesheet>