我正在尝试将ObservableCollection绑定到DockPanel ItemsControl。我希望能够通过数据绑定控制DockPanel中的MenuItems。我的方法似乎有点奏效,但是,它只展示了第一个元素' DockItems'。这是我的代码,
<ItemsControl DockPanel.Dock="Top" ItemsSource="{Binding DockItems}">
<ItemsControl.ItemTemplate>
<DataTemplate>
<Menu>
<MenuItem Header="File">
<MenuItem Header="{Binding Name}"/>
</MenuItem>
</Menu>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
答案 0 :(得分:0)
我能够通过添加ContentControl并使用ObservableCollection作为属性将其绑定到ViewModel来实现我想要的行为。我不确定为什么我需要这个额外的层来让事情有效,尽管我更喜欢这种方法。
<ContentControl Name="DockItemsContent" Content="{Binding DockItemsViewModel}">
<ContentControl.ContentTemplate>
<DataTemplate>
<DockPanel>
<Menu>
<MenuItem Header="File" ItemsSource="{Binding DockItems}">
<MenuItem.ItemTemplate>
<DataTemplate>
<MenuItem Header="{Binding Name}"/>
</DataTemplate>
</MenuItem.ItemTemplate>
</MenuItem>
</Menu>
</DockPanel>
</DataTemplate>
</ContentControl.ContentTemplate>
</ContentControl>
答案 1 :(得分:0)
根本不清楚你在这里尝试做什么。您正在创建ItemsControl,因此将为列表中的每个元素创建一个完全独立的菜单。每个菜单都有一个&#34;文件&#34;项目下面有一个列表项。没有用。
Menu和MenuItem都有一个ItemsSource,我怀疑你实际上要做的是:
<Menu>
<MenuItem Header="File" ItemsSource="{Binding DockItems}" DisplayMemberPath="Name"/>
</Menu>