• ASP.NET通过递归添加树(Treeview)


    先来看看效果,基本上就是这样的。

    所谓树,无非就是2点,第一个:根节点,第二:叶子节点,其中叶子节点中还可能有叶子节点,但是根节点始终只有一个。

    下面贴上 各部分的代码

    1.PAGE_LOAD载入事件。

        protected void Page_Load(object sender, EventArgs e)
        {
            BindTree(); //绑定树
        }
    

    2.BindTree方法。

        private void BindTree()
        {
          DataSet  ds = new DataSet(); //这里的DS里不存在数据,具体情况请大家自己具体考虑,修改代码
            
            TreeView1.Nodes.Clear(); 
    
            AddTree("-1", (TreeNode)null,ds);
            TreeView1.Nodes[0].Expanded = true;
        }
    

    3.AddTree方法,递归添加树。

     
    /*其中ds对应的是一个实体类Model,里面的IndexName,IndexID等,都是对应着数据库里的相应字段所以我们在使用这个方法时前,必须先得到相对应的有具体意义的DataSet*/
    
     /// <summary>
        /// 递归树
        /// </summary>
        /// <param name="ParentID">当前节点父节点ID</param>
        /// <param name="pNode"></param>
        /// <param name="ds"></param>
    private void AddTree(string ParentID, TreeNode pNode,DataSet ds)
        {
            DataView dvTree = new DataView(ds.Tables[0]); //用DataView来模拟DataTable,因为DV是虚拟的表,所以可以提高效率
            foreach (DataRowView Row in dvTree)
            {
                TreeNode node = new TreeNode();
                if (pNode == null)
                {         //添加根节点   
                    node.Text = Row["IndexName"].ToString();
                    node.Value = Row["IndexID"].ToString(); 
               
                    if (Row["IndexClass"].ToString() == "0")
                    {
                        node.NavigateUrl = "IndexInfo1.aspx?IndexID=" + node.Value;
                    }
                    else
                    {
                        node.NavigateUrl = "IndexInfo2.aspx?IndexID=" + node.Value;
                    }
                    
                    node.Target = "mainFrame";
                    node.Expanded = false;
                    TreeView1.Nodes.Add(node);  //添加根节点
                    AddTree(Row["IndexID"].ToString(), node,ds);         //递归,添加子节点,这段递归是必须的,不然只会添加根节点,而进不到下面的else语句,pNode在TreeView第二次执行以后都是不为空的,所以会一直跳到执行ELSE语句里的内容。   
                    
                }
                else
                {       //添加当前节点的子节点   
    
                    node.Text = Row["IndexName"].ToString();
                    node.Value = Row["IndexID"].ToString();
                    node.ToolTip = node.Text;   
                    if (Row["IndexClass"].ToString() == "0" || Row["IndexParentID"].ToString() == "-1")
                    {
                        
                        node.NavigateUrl = "IndexInfo1.aspx?IndexID=" + node.Value;
                    }
                    else
                    {
                       
                        node.NavigateUrl = "IndexInfo2.aspx?IndexID=" + node.Value;
                    }
                    
                    node.Target = "Frame1"; //某一个节点指向的一个IFRAME,里面可以是这个节点下的具体内容。
                    //node.NavigateUrl = Request.Url.LocalPath + "?OrgID=" + Row["OrgID"].ToString();
                    node.Expanded = false;
                    pNode.ChildNodes.Add(node); //pNode为父节点,把Node作为子节点添加进去
                    AddTree(Row["IndexID"].ToString(), node,ds);         //递归添加子节点 
                }
    
            }
    
        }
    

      

     

  • 相关阅读:
    裸二分图匹配poj1469
    洛谷——P2038 无线网络发射器选址
    洛谷—— P1041 传染病控制
    洛谷—— P1784 数独
    Vijos——T 1092 全排列
    Vijos—— T 1359 Superprime
    高并发解决方案--负载均衡
    request 发送多层字典
    June 11th 2017 Week 24th Sunday
    June 10th 2017 Week 23rd Saturday
  • 原文地址:https://www.cnblogs.com/kmsfan/p/3612958.html
Copyright © 2020-2023  润新知