在Omer van Kloeten的example之后,我填写了一个菜单,其中包含从我的可观察集合中绑定的菜单项。我为一个收集项目提供了一个菜单项。很好,但我真的想要更多。我还希望能够为一个收集项目创建一个包含两个或三个子项目的菜单项。这是一些粗略的草图:
What I Have What I Want
+ First Item + Create First Item
+ Second Item + Second Item
+ Delete
+ Update
此处“第一项”具有属性Exists = false
,但“第二项”具有true
。我目前的代码:
public class CollectionItem
{
public string Name { get; set; }
public bool Exists { get; set; }
}
public partial class MainWindow : Window
{
ObservableCollection<CollectionItem> items;
public MainWindow()
{
items = new ObservableCollection<CollectionItem>();
items.Add(new CollectionItem() { Name = "First Item", Exists = false });
items.Add(new CollectionItem() { Name = "Second Item", Exists = true });
AllItems.ItemsSource = items;
}
}
<MenuItem x:Name="AllItems" Header="What I Have">
<MenuItem.ItemContainerStyle>
<Style TargetType="{x:Type MenuItem}">
<Setter Property="Header" Value="{Binding Path=Name}" />
</Style>
</MenuItem.ItemContainerStyle>
</MenuItem>
如何将简单的菜单项与子项混合使用?
答案 0 :(得分:3)
如何将简单的菜单项与子项混合使用?
首先,您需要适当地构建数据,使用集合属性来表示子项或子MenuItem
。然后,您需要使用ItemsSource
将collection属性数据绑定到父MenuItem
的{{1}}属性,类似于您现在正在执行的操作。你应该得到这样的东西:
MenuItem.ItemContainerStyle
...
public class CollectionItem
{
public string Name { get; set; }
public bool Exists { get; set; }
public ObservableCollection<CollectionItem> CollectionOfSubItems { get; set; }
}