快速业务通道

Asp.net 2.0的TreeView客户端个性化控制

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-13
sp;GetParentByTagName(parentTagName, childElementObj)
{
    var parent = childElementObj.parentNode;
    while(parent.tagName.toLowerCase() != parentTagName.toLowerCase())
    {
        parent = parent.parentNode;
    }
    return parent;
}
//-----------------------------------------------------------------------------
</script>

  2. 只打开一个节点(关闭其他兄弟节点)

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>LeftMenu_Tree</title>
</head>
<body bgcolor="#DDEDFD">
    <form id="form1" runat="server">
        <a href="javascript:TreeviewExpandCollapseAll(''<%=TreeView1.ClientID%>'', true)">Expand
            All</a> , <a href="javascript:TreeviewExpandCollapseAll(''<%=TreeView1.ClientID%>'', false)">
                Collapse All</a>
        <asp:TreeView ID="TreeView1" SkinID="tvClass" runat="server" ShowLines="true" NodeWrap="false">
        </asp:TreeView>
    </form>
</body>
</html>

<script language="javascript">
//2. 只打开一个节点(关闭其他兄弟节点)------------------------------------------
function TreeView_ToggleNode(data, index, node, lineType, children) 
{
    var img = node.childNodes[0];
    var newExpandState;
    try {
        //***折叠兄弟节点------------------------
        CollapseBrothers(data,children);
        //---------------------------------------
            
        if (children.style.display == "none") 
        {
            children.style.display = "block";
            newExpandState = "e";
            if ((typeof(img) != "undefined") && (img != null)) 
            {
                if (lineType == "l") 
                {
                    img.src = data.images[15];
                }
                else if (lineType == "t") 
                {
                    img.src = data.images[12];
                }
                else if (lineType == "-") 
                {
                    img.src = data.images[18];
                }
                else 
                {
                    img.src = data.images[5];
                }
                img.alt = data.collapseToolTip.replace(/\{0\}/, TreeView_GetNodeText(node));
            }
        }
        else 
        {
            children.style.display = "none";
            newExpandState = "c";
            if ((typeof(img) != "undefined") && (img != null)) 
            {
                if (lineType == "l") 
                {
                    img.src = data.images[14];
                }
                else if (lineType == "t") 
                {
                    img.src = data.images[11];
                }
                else if (lineType == "-") 
                {
                    img.src = data.images[17];
                }
                else 
                {
                    img.src = data.images[4];
                }
                img.alt = data.expandToolTip.replace(/\{0\}/, TreeView_GetNodeText(node));
            }
        }
    }
    catch(e) {}
    data.expandState.value =  data.expandState.value.substring(0, index) + newExpandState + data.expandState.value.slice(index + 1);
}

//折叠兄弟节点
function CollapseBrothers(data,childContainer)
{
    var parent = childContainer.parentNode;   
    for(i=0; i< parent.childNodes.length; i++)
    {
        if(parent.childNodes[i].tagName.toLowerCase() =="div")
        {
            if(parent.childNodes[i].id != childContainer.id)
            {
                parent.childNodes[i].style.display = "none"
            }
        }
        else if(parent.childNodes[i].tagName.toLowerCase() =="table")
        {
            var treeLinks = parent.childNodes[i].getElementsByTagName("a");            
            if(treeLinks.length > 2)
            {
                var j=0;
                if(treeLinks[j].firstChild.tagName)
                {
                    if(treeLinks[j].firstChild.tagName.toLowerCase() == "img")
                    {
                        var img = treeLinks[j].firstChild;
                        if(i==0) 
                            img.src = data.images[8];
                        else if(i==parent.childNodes.length-2) 
                            img.src = data.images[14];
                        else 
                            img.src = data.images[11];
                    }
                }    
            }
        }        
    }
}
//-----------------------------------------------------------------------------
</script>

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号