WPF 实现一个带分组的下拉框
时间: 2024-11-24 12:41:40 浏览: 18
在WPF(Windows Presentation Foundation)中,要实现一个带分组的下拉框(通常称为“组合框”ComboBox),可以使用`ComboBox`控件结合`ItemsControl`(如`ListBox`)来构建。下面是一个简单的示例:
首先,在XAML文件中,创建一个带有`ItemsPanelTemplate`的`ComboBox`,这个模板用于定义分组部分:
```xml
<ComboBox x:Name="MyComboBox">
<ComboBox.ItemsPanel>
<ItemsPanelTemplate>
<WrapPanel Orientation="Vertical"/>
</ItemsPanelTemplate>
</ComboBox.ItemsPanel>
<ComboBox.ItemTemplate>
<!-- 分组模板 -->
<HierarchicalDataTemplate ItemsSource="{Binding}">
<TextBlock Text="{Binding GroupHeader}" Foreground="DarkGray" Margin="5"/>
<ListBox ItemsSource="{Binding Items}">
<ListBox.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding DisplayMemberPath}"/>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</HierarchicalDataTemplate>
</ComboBox.ItemTemplate>
</ComboBox>
```
然后,在代码背后,你需要准备数据模型(例如`ICollectionView`、`ObservableCollection`或自定义类)来存储分组结构,其中包含`GroupHeader`和`Items`两个属性。
举个例子,你可以有一个类`CategoryItem`,它有两个字段`GroupName`和`Items`:
```csharp
public class CategoryItem
{
public string GroupName { get; set; }
public ObservableCollection<string> Items { get; set; } // 这里假设你的子项是字符串
}
```
最后,将数据绑定到组合框上,并填充数据:
```csharp
// 假设categories是一个包含CategoryItem的对象列表
MyComboBox.ItemsSource = categories;
```
现在,当你在下拉框中选择一个选项时,它会按照分组显示。如果你需要动态添加或移除分组,记得更新`Items`属性。
阅读全文