使用c#递归填充树视图

时间:2013-08-02 15:18:41

标签: c# recursion treeview

我有一个类型列表的对象,我希望用它来填充c#中的树视图。 我为我的对象

创建了一个MyObject类
public class MyObject
{
    public int Id;
    public int ParentId;
    public string Name;
}

这是一种基于列表recursivley添加树视图节点的方法。

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        List<MyObject> list = new List<MyObject>();
        list.Add(new MyObject(){Id=1, Name="Alice", ParentId=0});
        list.Add(new MyObject(){Id=2, Name="Bob", ParentId=1});
        list.Add(new MyObject(){Id=3, Name="Charlie", ParentId=1});
        list.Add(new MyObject(){Id=4, Name="David", ParentId=2});            

        BindTree(list, null);            
    }
}

private void BindTree(IEnumerable<MyObject> list, TreeNode parentNode)
{
    var nodes = list.Where(x => parentNode == null ? x.ParentId == 0 : x.ParentId == int.Parse(parentNode.Value));
    foreach (var node in nodes)
    {
        TreeNode newNode = new TreeNode(node.Name, node.Id.ToString());
        if (parentNode == null)
        {
            treeView1.Nodes.Add(newNode);
        }
        else
        {
            parentNode.ChildNodes.Add(newNode);
        }
        BindTree(list, newNode);
    }
}

但是如果我评论这一行,方法就失败了:

list.Add(new MyObject(){Id=1, Name="Alice", ParentId=0});

有人有简单的解决方案吗?

1 个答案:

答案 0 :(得分:0)

该方法会失败,因为在评论之后:

list.Add(new MyObject(){Id=1, Name="Alice", ParentId=0});

因为您的列表中没有ParentId为0的对象。问题在于您首先使用空BindTree调用TreeNode

BindTree(list, null);

这意味着BindTree中的第一行代码会将nodes设置为空的可枚举:

var nodes = list.Where(x => parentNode == null ? x.ParentId == 0 : x.ParentId == int.Parse(parentNode.Value));
// 'parentNode' is null, so it looks for items in 'list' that have a 'ParentId' of '0'

在这种情况下,没有任何项目的ParentId为0 ...