TreeView(经典递归算法)

这篇博客介绍如何利用C#实现TreeView控件的填充,通过递归算法从数据库中获取组织机构数据,创建层次结构。文章展示了具体的代码实现,包括连接数据库、筛选数据以及递归添加节点的过程。
 前台
  1. <%@ Page Language="C#" AutoEventWireup="true" CodeFile="test_TreeView.aspx.cs" Inherits="test_test_TreeView" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" >
  4. <head runat="server">
  5.     <title>无标题页</title>
  6. </head>
  7. <body>
  8.     <form id="form1" runat="server">
  9.     <div>
  10.         <asp:TreeView ID="treeView1" runat="server">
  11.         </asp:TreeView>
  12.     
  13.     </div>
  14.     </form>
  15. </body>
  16. </html>
后台
  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Collections;
  5. using System.Web;
  6. using System.Web.Security;
  7. using System.Web.UI;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using System.Web.UI.HtmlControls;
  11. using System.Data.SqlClient;
  12. public partial class test_test_TreeView : System.Web.UI.Page
  13. {
  14.     private DataTable tblSetOrgInfo = new DataTable();//储存读入的数据
  15.     protected void Page_Load(object sender, EventArgs e)
  16.     {
  17.         Bind();
  18.     }
  19.     private void Bind()
  20.     {
  21.         string connStr = ConfigurationManager.ConnectionStrings["hrmbookConnectionString"].ToString();
  22.         SqlConnection conn = new SqlConnection(connStr);
  23.         try
  24.         {
  25.             conn.Open();
  26.             string Sqlstr = "SELECT 内部编号, 类别, AbsIndex, ItemIndex, ItemLevel, ParentIndex, 类别号, 单位编号, "
  27.                 +"单位名称, 拼音编码, 单位地址, 单位电话号码, 开户银行, 帐号, 开户全称 FROM 组织机构编码表 ORDER BY AbsIndex";
  28.             SqlDataAdapter da = new SqlDataAdapter(Sqlstr, conn);
  29.             da.Fill(tblSetOrgInfo);
  30.             DataTable tempDataTable = tblSetOrgInfo.Copy();//将组织机构表另存一份为tempDataTable
  31.             DataView viewSetOrgInfo = new DataView(tempDataTable);//新建一个数据视图
  32.             viewSetOrgInfo.RowFilter = "ItemLevel = 0";
  33.             //将数据集中的所有记录逐个根据他们之间的关系添加到树形表中去
  34.             if (viewSetOrgInfo.Count > 0)
  35.             {
  36.                 foreach (DataRowView myRow in viewSetOrgInfo)
  37.                 {
  38.                     string strEnterpriseName = myRow["单位名称"].ToString().Trim();
  39.                     //此处是添加第一个节点“省医药集团”
  40.                     this.treeView1.Nodes.Add(new TreeNode(strEnterpriseName));
  41.                     //此处初始化参数是第一个节点“省医药集团”,然后该函数会递归添加所有子节点
  42.                     PopulateTreeView(strEnterpriseName, treeView1.Nodes[0], myRow);
  43.                     //treeView1.SelectedNode = treeView1.Nodes[0]; //选中第一个节点 
  44.                 }
  45.             }
  46.         }
  47.         catch (Exception ex)
  48.         {
  49.             Response.Write(ex.ToString());
  50.         }
  51.         finally
  52.         {
  53.             conn.Close();
  54.         }
  55.     }
  56.     //---------------根据输入的节点信息,递归调用最终添加所有的节点-----------------------
  57.     private void PopulateTreeView(string parentPart, TreeNode parentNode, DataRowView parentRow)
  58.     {
  59.         string strEnterpriseName = "";
  60.         DataTable tempDataTable = tblSetOrgInfo.Copy();
  61.         DataView viewSetOrgInfo = new DataView(tempDataTable);
  62.         //筛选获得当前传递过来的节点的子项,并将其添加到树形图中
  63.         //判断方法是凡parentIndex等于传递过来的节点的absIndex的,就是该节点的子项
  64.         viewSetOrgInfo.RowFilter = "ParentIndex = '" + parentRow["AbsIndex"].ToString().Trim() + "'";
  65.         //递归的添加每一个节点的所有子节点
  66.         foreach (DataRowView myRow in viewSetOrgInfo)
  67.         {
  68.             strEnterpriseName = myRow["单位名称"].ToString().Trim();
  69.             TreeNode myNode = new TreeNode(strEnterpriseName);
  70.             parentNode.ChildNodes.Add(myNode);
  71.             //函数递归调用,将所有节点按顺序添加完毕
  72.             PopulateTreeView(strEnterpriseName, myNode, myRow);
  73.         }
  74.     }
  75. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值