我有一个类型列表的对象,我希望用它来填充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});
有人有简单的解决方案吗?
答案 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 ...