7

次の列を含むアカウント テーブルをデータベースに作成しました。

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からも試しましたが、まだわかりません。

4

2 に答える 2

6

複雑なアルゴリズムを作成するために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);
     }

 }

それは私にとって地獄のように働いた、私はそれが役立つことを願っています!

于 2013-05-29T16:33:44.650 に答える