Fork me on GitHub

C#递归加载树

递归,就是有去有回,自己调用自己。

 1 public partial class SiteMaster : MasterPage
 2     {
 3         public DataSet list = null;
 4 
 5         public List<TreeData> treeDatas = new List<TreeData>();
 6         string str = "";
 7         protected void Page_Load(object sender, EventArgs e)
 8         {
 9             if (LoginMITBz.currentUser == null)
10             {
11                 Response.Redirect("/Login/Login.aspx");
12             }
13             string sql = "SELECT a.Title,a.TreeId,a.Url,a.ParentID,a.ParentPath FROM dbo.M_Tree a INNER JOIN dbo.M_Permissions b ON a.TreeId = b.TreeId WHERE b.UserId=" + LoginMITBz.currentUser.UserId;
14             list = Hy.DBSqlU.DBUtility_USA.DbHelperSQLDB_USA_MIT_MitInfo.Query(sql);
15             #region Test
16 
17             //foreach (DataRow mDr in list.Tables[0].Rows)
18             // {
19             // DataColumn mDc = list.Tables[0].Columns[0];
20             //Console.WriteLine(mDr["Title"].ToString());
21             //Console.WriteLine(mDr["Url"].ToString());
22 
23             //    //foreach (DataColumn mDc in list.Tables[0].Columns)
24             //    //{
25             //    //    Console.WriteLine(mDr["Title"].ToString());
26             //    //    Console.WriteLine(mDr["Url"].ToString());
27             //    //}
28             //}
29             #endregion
30 
31             foreach (DataRow mDr in list.Tables[0].Rows)
32             {
33                 DataColumn mDc = list.Tables[0].Columns[0];
34                 TreeData tree = new TreeData();
35                 tree.TreeId = (long)mDr["TreeId"];
36                 tree.Title = mDr["Title"].ToString();
37                 tree.Url = mDr["Url"].ToString();
38                 tree.ParentId = (int)mDr["ParentID"];
39                 treeDatas.Add(tree);
40             }
41 
42            
43             var data = treeDatas.Where(a => a.ParentId == 0);
44             foreach (var item in data)
45             {
46                 str += item.Title + ":" + item.Url + "\r\n";
47                 GetNode((int)item.TreeId);
48             }
49         }
50         
51         public  void GetNode(int parentId)
52         {
53             var data = treeDatas.Where(a => a.ParentId == parentId);
54             foreach (var item in data)
55             {
56                 str += item.Title + ":" + item.Url + "\r\n";
57                 GetNode((int)item.TreeId);
58             }
59         }
60     }
61     
62 
63 
64     public class TreeData
65     {
66         public long? TreeId { get; set; }
67         public int? ParentId { get; set; }
68         public string Title { get; set; }
69         public string Url { get; set; }
70     }

posted @ 2018-06-08 10:57  秋刀鱼de滋味  阅读(1466)  评论(0编辑  收藏  举报