前言:Treeview控制元件是我們在WinForm、WebForm開發中經常使用的控制元件,需要從資料庫動態載入資料,然後遞迴繫結每一個節點;同樣,遞迴的思路在其他程式中也經常運用,包括.Net MVC等。
通過網上查詢,繫結TreeView控制元件的方法非常多,我經過自己思考並且結合工作經驗,總結了一個最簡單的繫結方法,供大家參考。
效果圖:
資料庫表:
程式碼
VB.net:
1 Private Sub BindTreeView() 2 TreeView1.Nodes.AddRange(GetChildNodes(dt, 0)) 3 End Sub 4 5 Private Function GetChildNodes(dt As DataTable, pId As Integer) As TreeNode() 6 Dim nodes As New List(Of TreeNode) 7 Dim rows = dt.AsEnumerable().Where(Function(s) CInt(s("pId")) = pId) 8 For Each row In rows 9 Dim node As New TreeNode() 10 node.Text = row("Name") 11 node.Tag = row("id") 12 node.Nodes.AddRange(GetChildNodes(dt, CInt(row("id")))) 13 nodes.Add(node) 14 Next 15 Return nodes.ToArray() 16 End Function
C#:
1 private void BindTreeView() 2 { 3 treeView1.Nodes.AddRange(GetChildNodes(dt, 0)); 4 } 5 6 private TreeNode[] GetChildNodes(DataTable dt, int pId) 7 { 8 var nodes = new List<TreeNode>(); 9 var rows = dt.AsEnumerable().Where(s => Convert.ToInt32(s["pId"]) == pId); 10 foreach(var row in rows) 11 { 12 var node = new TreeNode(); 13 node.Text = row["Name"].ToString(); 14 node.Tag = row["Tag"].ToString(); 15 node.Nodes.AddRange(GetChildNodes(dt, Convert.ToInt32(row["Tag"]))); 16 nodes.Add(node); 17 } 18 return nodes.ToArray(); 19 }
.net工作札記系列: