我正在尝试创建一个TreeView,每行包含许多列数据(例如我的示例中的2列,属性和值),类似于this thread。 Heena提出的解决方案的不同之处在于树可能稍微复杂一些。每个分支的深度可能不同(因此在某些情况下,节点可能会有更多的子节点)。
我会用以下类来实现代码,这样嵌套元素是可能的:
public class TreeItem
{
private TreeItem()
{
}
public TreeItem( string property, string value )
{
if( property == null )
{
property = string.Empty;
}
if( value == null )
{
value = string.Empty;
}
_property = property;
_value = value;
}
public TreeItem( params TreeItem[] items )
{
AddItems( items );
}
public TreeItem( string property, string value, params TreeItem[] items ) : this( property, value )
{
AddItems( items );
}
public string Property
{
get
{
return _property;
}
}
public string Value
{
get
{
return _value;
}
}
public IEnumerable<TreeItem> Items
{
get
{
return (IEnumerable<TreeItem>)_items;
}
}
private void AddItems( params TreeItem[] items )
{
foreach( TreeItem item in items )
{
if( item != null )
{
_items.Add( item );
}
}
}
private readonly string _property;
private readonly string _value;
private readonly List<TreeItem> _items = new List<TreeItem>();
}
用WPF可以实现这一点吗?如果是,怎么样?