我的 .edmx ADO.NET 实体数据模型文件中有一个 Page 类,其中包含 Parent 和 Children 属性。它用于页面的层次结构。
删除了死 ImageShack 链接 - ADO.NET 实体框架分层页面类
这是在我的 SQL 数据库中处理的,Page 表中的 ParentId 外键绑定到同一个 Page 表的 Id 主键。
如何在 WPF TreeView 中显示此层次结构?
我的 .edmx ADO.NET 实体数据模型文件中有一个 Page 类,其中包含 Parent 和 Children 属性。它用于页面的层次结构。
删除了死 ImageShack 链接 - ADO.NET 实体框架分层页面类
这是在我的 SQL 数据库中处理的,Page 表中的 ParentId 外键绑定到同一个 Page 表的 Id 主键。
如何在 WPF TreeView 中显示此层次结构?
我在Abe Heidebrecht的帮助下完成了这项工作。非常感谢他。
这是我的 XAML ......
<Window x:Class="Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:PageManager"
Title="Window1" Height="300" Width="300" Name="Window1">
<Grid>
<TreeView Margin="12" Name="TreeViewPages" ItemsSource="{Binding}" TreeViewItem.Expanded="TreeViewPages_Expanded">
<TreeView.Resources>
<HierarchicalDataTemplate DataType="{x:Type local:Page}" ItemsSource="{Binding Children}">
<TextBlock Text="{Binding Path=ShortTitle}" />
</HierarchicalDataTemplate>
</TreeView.Resources>
</TreeView>
</Grid>
</Window>
这是我的 Visual Basic 代码...
Class Window1
Private Sub Window1_Loaded(ByVal sender As System.Object, ByVal e As System.Windows.RoutedEventArgs) Handles MyBase.Loaded
Dim db As New PageEntities
Dim RootPage = From p In db.Page.Include("Children") _
Where (p.Parent Is Nothing) _
Select p
TreeViewPages.ItemsSource = RootPage
End Sub
Private Sub TreeViewPages_Expanded(ByVal sender As System.Object, ByVal e As System.Windows.RoutedEventArgs)
Dim ExpandedTreeViewItem As TreeViewItem = DirectCast(e.OriginalSource, TreeViewItem)
Dim PageId As Guid = DirectCast(ExpandedTreeViewItem.DataContext, Page).Id
Dim db As New PageEntities
Dim ChildPages = From p In db.Page.Include("Children") _
Where p.Parent.Id = PageId _
Select p
ExpandedTreeViewItem.ItemsSource = ChildPages
End Sub
End Class
当窗口加载时,从数据库中查询根节点及其子节点并将其插入树中。
每次展开节点时,都会从数据库中查询该节点的子节点和孙节点并将其插入树中。
一种不同的方式:(嗯,非常相似,但略有不同)
在您的窗口加载功能中:
PageEntities db = new PageEntities();
TreeViewPages.ItemsSource = db.Page.Where(u=>u.Parent==null);
创建一个新文件 Page.cs
public partial class Page {
public ObjectQuery<Page> LoadedChildren {
get {
var ret = Children;
if(ret.IsLoaded==false) ret.Load();
return ret;
}
}
}
在您的 XAML 中:
<TreeView Name="TreeViewPages">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemSource="{Binding LoadedChildren}">
<TextBlock Text="{Binding ShortTitle}" />
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
它没有经过测试,但你应该得到一般的想法。
第二种解决方案最适合我。我有一个递归对象列表,所以这是我使用的 XAML:
<TreeView Height="Auto" HorizontalAlignment="Stretch" Name="trvVaults" VerticalAlignment="Stretch" Width="Auto" Grid.Column="0" Margin="5">
<!-- Treeview ItemsSource is loaded programmatically -->
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding Vaults}">
<TextBlock Text="{Binding Name}" />
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
每个“Vault”对象都有几个属性(名称、位置等)和一个“Vaults”的通用列表。