从包含树状数据的数据表或列表填充TreeView

Populate TreeView from DataTable or List that contains tree-like data(从包含树状数据的数据表或列表填充TreeView)

本文介绍了从包含树状数据的数据表或列表填充TreeView的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我已经在数据库中创建了一个ACCOUNT表,其中包含以下各列:

ID
Name
ParentID

这是记录存储方式的示例:

ID   Name    ParentID
1    BANK A  0
2    0001    1
3    0002    1
4    BANK B  0
5    0001    4
6    0002    4

但是公司名称不是来自数据库,而是来自代码。那么我怎样才能像这样展开TreeView呢?

├─ BANK A
│  ├─ 0001
│  └─ 0002
└─ BANK B
   ├─ 0001
   └─ 0002

如何在C#中执行此操作?我也尝试了HERE,但还是不懂。

推荐答案

我花了2小时编写了复杂的算法,找到了一段非常适合我的代码:

 //In Page load
 //select where id is null to retrieve the parent nodes 
 //in a datatable (called table here)
 foreach (DataRow row in table.Rows)
 {
   TreeNode node = new TreeNode();
   node.Text = row["title"].ToString();
   node.Value = row["id"].ToString();
   //you can affect the node.NavigateUrl

   node.PopulateOnDemand = true;
   TreeView1.Nodes.Add(node);
 }

然后创建TreeNodePopulate事件:

 protected void TreeView1_TreeNodePopulate(Object sender, TreeNodeEventArgs e)
 {
     string id= e.Node.Value;
     //do your "select from yourTable where parentId =" + id;

     foreach (DataRow row in table.Rows)
     {
         TreeNode node = new TreeNode(row["title"], row["id"])
         node.PopulateOnDemand = true;    
         e.Node.ChildNodes.Add(node);
     }

 }

这对我来说简直是地狱般的工作,我希望它能帮上忙!

这篇关于从包含树状数据的数据表或列表填充TreeView的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:从包含树状数据的数据表或列表填充TreeView