这里是js
var ImgDir;
var indexOfEntries = new Array;
var nEntries = 0;
var doc = document;
var browserVersion = 0;
var auxs = new Array;
var FolderOpenIcon = "fopen.gif";
var FolderCloseIcon = "fclose.gif";
var treeClass=0;
var parentLevel=0;function SetFolderIcon(iOpen, iClose)
{
var aux;
if(!iOpen)
{
iOpen = "fopen.gif";
iClose = "fclose.gif";
} if(!iClose)iClose = iOpen; aux = new Image();
aux.src= ImgDir + iOpen;
aux = new Image();
aux.src= ImgDir + iClose; FolderOpenIcon = iOpen;
FolderCloseIcon = iClose;
}function loadImages()
{
var aux; aux = new Image();
aux.src= ImgDir + "blank.gif";
aux = new Image();
aux.src= ImgDir + "lastnode.gif";
aux = new Image();
aux.src= ImgDir + "link.gif";
aux = new Image();
aux.src= ImgDir + "mlastnode.gif";
aux = new Image();
aux.src= ImgDir + "mnode.gif";
aux = new Image();
aux.src= ImgDir + "node.gif";
aux = new Image();
aux.src= ImgDir + "plastnode.gif";
aux = new Image();
aux.src= ImgDir + "pnode.gif";
aux = new Image();
aux.src= ImgDir + "vertline.gif";
}function Folder(folderDescription, isDefOpen)
{
this.desc = folderDescription;
this.id = -1;
this.navObj = 0;
this.iconImg = 0;
this.nodeImg = 0;
this.isLastNode = 0;
this.isDefOpen = isDefOpen; this.isOpen = true;
this.iconSrc = FolderOpenIcon;
this.iconOpen = FolderOpenIcon;
this.iconClose = FolderCloseIcon;
this.children = new Array;
this.nChildren = 0; this.initialize = initializeFolder;
this.setState = setStateFolder;
this.addChild = addChild;
this.createIndex = createEntryIndex;
this.hide = hideFolder;
this.display = display;
this.renderOb = drawFolder;
this.totalHeight = totalHeight;
this.subEntries = folderSubEntries;
}function setStateFolder(isOpen)
{
var subEntries;
var totalHeight;
var fIt = 0;
var i=0; if (isOpen == this.isOpen)
return; if (browserVersion == 2)
{
totalHeight = 0;
for (i=0; i < this.nChildren; i++)
totalHeight = totalHeight + this.children[i].navObj.clip.height;
subEntries = this.subEntries();
if (this.isOpen)
totalHeight = 0 - totalHeight;
for (fIt = this.id + subEntries + 1; fIt < nEntries; fIt++)
indexOfEntries[fIt].navObj.moveBy(0, totalHeight);
}
this.isOpen = isOpen;
propagateChangesInState(this);
}

解决方案 »

  1.   

    function propagateChangesInState(folder)
    {
    var i=0; if (folder.isOpen)
    {
    if (folder.nodeImg)
    if (folder.isLastNode)
    folder.nodeImg.src = ImgDir + "mlastnode.gif";
    else
    folder.nodeImg.src = ImgDir + "mnode.gif";
    folder.iconImg.src = ImgDir + folder.iconOpen;
    for (i=0; i<folder.nChildren; i++)
    folder.children[i].display();
    }
    else
    {
    if (folder.nodeImg)
    if (folder.isLastNode)
    folder.nodeImg.src = ImgDir + "plastnode.gif";
    else
    folder.nodeImg.src = ImgDir + "pnode.gif";
    folder.iconImg.src = ImgDir + folder.iconClose;
    for (i=0; i<folder.nChildren; i++)
    folder.children[i].hide();

    }function hideFolder()
    {
    if (browserVersion == 1)
    {
    if (this.navObj.style.display == "none")
    return;
    this.navObj.style.display = "none";
    }else
    {
    if (this.navObj.visibility == "hiden")
    return;
    this.navObj.visibility = "hiden";
    } this.setState(0);
    }function initializeFolder(level, lastNode, leftSide)
    {
    var j=0;
    var i=0;
    var numberOfFolders;
    var numberOfDocs;
    var nc;
    nc = this.nChildren; this.createIndex(); var auxEv = "";

    if (browserVersion > 0)
    {
    auxEv = "<a href='#' onclick='return clickOnNode("+this.id+");'";
    auxEv = auxEv + ' title=\"' + this.desc + '\">';
    }
    else
    {
    auxEv = "<a>";
    } if (level>0)
    if (lastNode)
    {
    this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' src='" + ImgDir + "mlastnode.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0 border=0>");
    leftSide = leftSide + "<img src='" + ImgDir + "blank.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0>";
    this.isLastNode = 1;
    }else
    {
    this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' src='" + ImgDir + "mnode.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0 border=0>");
    leftSide = leftSide + "<img src='" + ImgDir + "vertline.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0>";
    this.isLastNode = 0;
    }
    else
    this.renderOb(auxEv); if (nc > 0)
    {
    level = level + 1;
    for (i=0 ; i < this.nChildren; i++)
    {
    if (i == this.nChildren-1)
    this.children[i].initialize(level, 1, leftSide);
    else
    this.children[i].initialize(level, 0, leftSide);
    }
    }
    }function drawFolder(leftSide)
    {
    if (browserVersion == 2)
    {
    if (!doc.yPos)
    doc.yPos=100;
    doc.write("<layer id='folder" + this.id + "' top=" + doc.yPos + ">\n<style type=\"text/css\">\ntd {font-size: 9pt}\na {color: #000000; text-decoration:none;}\n</style>");
    }
    doc.write("<table ");
    if (browserVersion == 1)
    doc.write(" id='folder" + this.id + "' style='position:block;' ");
    doc.write(" border=0 cellspacing=0 cellpadding=0>");
    doc.write("<tr valign=top><td nowrap>");
    doc.write(leftSide);
    doc.write("<img name='folderIcon" + this.id + "' ");
    doc.write("src='" + ImgDir + this.iconSrc+"'  width=18 height=18 align=left border=0 vspace=0 hspace=0 border=0>");
    doc.write("<font color="+'black'+">" + this.desc + "</font></a>");
    doc.write("</td>");
    doc.write("</table>");

    if(browserVersion == 2)
    doc.write("</layer>"); if (browserVersion == 1)
    {
    this.navObj = doc.all["folder"+this.id];
    this.iconImg = doc.all["folderIcon"+this.id];
    this.nodeImg = doc.all["nodeIcon"+this.id];
    }else if (browserVersion == 2)
    {
    this.navObj = doc.layers["folder"+this.id];
    this.iconImg = this.navObj.document.images["folderIcon"+this.id];
    this.nodeImg = this.navObj.document.images["nodeIcon"+this.id];
    doc.yPos=doc.yPos+this.navObj.clip.height;
    }
    }function addChild(childNode)
    {
    this.children[this.nChildren] = childNode;
    this.nChildren++;
    return childNode;
    }function folderSubEntries()
    {
    var i = 0;
    var se = this.nChildren; for (i=0; i < this.nChildren; i++)
    {
    if (this.children[i].children)
    se = se + this.children[i].subEntries();
    } return se;
    }
      

  2.   

    function Item(itemDescription, itemLink, itemIcon)
    {
    var aux this.desc = itemDescription;
    this.link = itemLink;
    this.id = -1;
    this.navObj = 0;
    this.iconImg = 0;
    if(itemIcon)
    {
    this.iconSrc = itemIcon; aux = new Image();
    aux.src= ImgDir + itemIcon;
    }else this.iconSrc = "doc.gif"; this.initialize = initializeItem;
    this.createIndex = createEntryIndex;
    this.hide = hideItem;
    this.display = display;
    this.renderOb = drawItem;
    this.totalHeight = totalHeight;
    }function hideItem()
    {
    if (browserVersion == 1)
    {
    if (this.navObj.style.display == "none")
    return;
    this.navObj.style.display = "none";
    }else
    {
    if (this.navObj.visibility == "hiden")
    return;
    this.navObj.visibility = "hiden";
    }
    }function initializeItem(level, lastNode, leftSide)
    {
    this.createIndex(); if (level>0)
    if (lastNode)
    {
    this.renderOb(leftSide + "<img src='" + ImgDir + "lastnode.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0>");
    leftSide = leftSide + "<img src='" + ImgDir + "blank.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0>" ;
    }
    else
    {
    this.renderOb(leftSide + "<img src='" + ImgDir + "node.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0>");
    leftSide = leftSide + "<img src='" + ImgDir + "vertline.gif' width=18 height=18 align=left border=0 vspace=0 hspace=0 align=left border=0 vspace=0 hspace=0>";
    }
    else
    this.renderOb("");
    }function drawItem(leftSide)
    {
    if (browserVersion == 2)
    doc.write("<layer id='item" + this.id + "' top=" + doc.yPos + ">");
    doc.write("<table ");
    if (browserVersion == 1)
    doc.write(" id='item" + this.id + "' style='position:block;' ");
    doc.write(" border=0 cellspacing=0 cellpadding=0>");
    doc.write("<tr valign=top><td nowrap>");
    doc.write(leftSide);
    doc.write("<a href=" + this.link );
    doc.write(' title=\"' + this.desc + '\" onclick=\"javascript:Db_Clk(this);\">');
    if(browserVersion == 2)
    {
    doc.write("<layer id=showname bgcolor=#FFFFD2 visibility=hide>"+this.desc+"</layer>");
    }

    doc.write("<img id='itemIcon"+this.id+"' ");
    doc.write("src='" + ImgDir + this.iconSrc+"'  width=18 height=18 align=left border=0 vspace=0 hspace=0 border=0>");
    doc.write("<font color="+'black'+">" + this.desc + "</font></a>");
    doc.write("</table>"); if (browserVersion == 2)
    doc.write("</layer>"); if (browserVersion == 1)
    {
    this.navObj = doc.all["item"+this.id];
    this.iconImg = doc.all["itemIcon"+this.id];
    }else if (browserVersion == 2)
    {
    this.navObj = doc.layers["item"+this.id];
    this.iconImg = this.navObj.document.images["itemIcon"+this.id];
    doc.yPos=doc.yPos+this.navObj.clip.height;
    }
    }function display()
    {
    if (browserVersion == 1)
    this.navObj.style.display = "block";
    else
    this.navObj.visibility = "show";
    }function createEntryIndex()
    {
    this.id = nEntries;
    indexOfEntries[nEntries] = this;
    nEntries++;
    }function totalHeight()
    {
    var h = this.navObj.clip.height;
    var i = 0; if (this.isOpen)
    for (i=0 ; i < this.nChildren; i++);
    h = h + this.children[i].totalHeight(); return h;
    }function clickOnNode(folderId)
    {
    var clickedFolder = 0;
    var state = 0; clickedFolder = indexOfEntries[folderId];
    state = clickedFolder.isOpen; clickedFolder.setState(!state);
    if(!folderId)clickedFolder.setState(state);
    return false;
    }function initializeDocument()
    {
    loadImages();
    foldersTree = auxs[0];
    if (doc.all)
    browserVersion = 1;
    else
    if (doc.layers)
    browserVersion = 2;
    else
    browserVersion = 0; foldersTree.initialize(0, 1, ""); if (browserVersion > 0)
    {
    doc.write("<layer top="+indexOfEntries[nEntries-1].navObj.top+">&nbsp;</layer>");
    clickOnNode(0);
    }
    }function treeMenuAddItem(level, text, url, target, icon)
    {

    if (!target)
    {
    parentLevel=level;
    if(level)
    auxs[level] = auxs[level - 1].addChild(new Folder(text, url));
    else auxs[0] = new Folder(text);
    }
    else
    {
    if(level>parentLevel + 1)level = parentLevel + 1;
    auxs[level - 1].addChild(new Item(text, "'"+url+"' target=\"" + target + "\"", icon));
    }
    }function Db_Clk(Clked)
    {

    var s_Href = Clked.href;
    var i = s_Href.indexOf("&dbc=");
    if(i!=-1)
    {
    if(s_Href.indexOf("&dbc=10") != -1)s_Href = s_Href.substring(0, i);
    else s_Href += "0";
    Clked.href = s_Href;
    }
    }