0


C# WPF入门学习主线篇(九)—— ComboBox常见属性和事件

欢迎来到C# WPF入门学习系列的第九篇。在前面的文章中,我们已经学习了

Button

TextBox

Label

ListBox

控件。今天,我们将探讨 WPF 中的另一个重要控件——

ComboBox

。本文将详细介绍

ComboBox

的常见属性和事件,并通过示例代码展示其在实际应用中的使用。

一、ComboBox的基础知识

ComboBox

是一个下拉列表控件,允许用户从预定义的选项中选择一个。它结合了

TextBox

ListBox

的功能,用户可以选择现有项或输入新的值。
在这里插入图片描述

ComboBox的基本定义

我们先来看看一个简单的

ComboBox

定义:

<Windowx:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="MainWindow"Height="350"Width="525"><Grid><ComboBoxx:Name="myComboBox"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox></Grid></Window>

在这个示例中,我们定义了一个

ComboBox

控件,并添加了三个

ComboBoxItem

项目。

二、ComboBox的常见属性

1. ItemsSource

ItemsSource

属性用于绑定

ComboBox

的数据源。可以是数组、列表或任何实现了

IEnumerable

接口的集合。

<ComboBoxx:Name="myComboBox"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"/>
publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();
        myComboBox.ItemsSource =newList<string>{"Option 1","Option 2","Option 3"};}}

2. SelectedItem

SelectedItem

属性用于获取或设置当前选定的项目。

string selectedItem = myComboBox.SelectedItem asstring;

3. SelectedIndex

SelectedIndex

属性用于获取或设置当前选定项目的索引。

int selectedIndex = myComboBox.SelectedIndex;

4. IsEditable

IsEditable

属性用于设置

ComboBox

是否可编辑。默认值为

False

<ComboBoxx:Name="myComboBox"IsEditable="True"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox>

5. DisplayMemberPath

DisplayMemberPath

属性用于设置显示成员路径,当数据源为对象集合时,指定显示对象的哪个属性。

<ComboBoxx:Name="myComboBox"DisplayMemberPath="Name"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"/>

示例

下面是一个包含以上常见属性的完整示例:

<ComboBoxx:Name="myComboBox"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"ItemsSource="{Binding Items}"DisplayMemberPath="Name"IsEditable="True"/>
publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();this.DataContext =this;
        Items =newList<Item>{newItem{ Name ="Option 1"},newItem{ Name ="Option 2"},newItem{ Name ="Option 3"}};}publicList<Item> Items {get;set;}}publicclassItem{publicstring Name {get;set;}}

三、ComboBox的常见事件

1. SelectionChanged

SelectionChanged

事件在选择的项目发生更改时触发。

XAML代码
<ComboBoxx:Name="myComboBox"SelectionChanged="MyComboBox_SelectionChanged"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox>
后台代码
privatevoidMyComboBox_SelectionChanged(object sender,SelectionChangedEventArgs e){ComboBox comboBox = sender asComboBox;string selectedItem = comboBox.SelectedItem asstring;
    MessageBox.Show($"Selected Item: {selectedItem}");}

2. DropDownOpened

DropDownOpened

事件在下拉列表打开时触发。

XAML代码
<ComboBoxx:Name="myComboBox"DropDownOpened="MyComboBox_DropDownOpened"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox>
后台代码
privatevoidMyComboBox_DropDownOpened(object sender,EventArgs e){
    MessageBox.Show("ComboBox DropDown opened");}

3. DropDownClosed

DropDownClosed

事件在下拉列表关闭时触发。

XAML代码
<ComboBoxx:Name="myComboBox"DropDownClosed="MyComboBox_DropDownClosed"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox>
后台代码
privatevoidMyComboBox_DropDownClosed(object sender,EventArgs e){
    MessageBox.Show("ComboBox DropDown closed");}

示例总结

以下是一个包含所有三种常见事件的完整示例:

<Windowx:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="MainWindow"Height="350"Width="525"><Grid><ComboBoxx:Name="myComboBox"SelectionChanged="MyComboBox_SelectionChanged"DropDownOpened="MyComboBox_DropDownOpened"DropDownClosed="MyComboBox_DropDownClosed"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBoxItemContent="Option 1"/><ComboBoxItemContent="Option 2"/><ComboBoxItemContent="Option 3"/></ComboBox></Grid></Window>
usingSystem;usingSystem.Windows;usingSystem.Windows.Controls;namespaceWpfApp{publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();}privatevoidMyComboBox_SelectionChanged(object sender,SelectionChangedEventArgs e){ComboBox comboBox = sender asComboBox;string selectedItem = comboBox.SelectedItem asstring;
            MessageBox.Show($"Selected Item: {selectedItem}");}privatevoidMyComboBox_DropDownOpened(object sender,EventArgs e){
            MessageBox.Show("ComboBox DropDown opened");}privatevoidMyComboBox_DropDownClosed(object sender,EventArgs e){
            MessageBox.Show("ComboBox DropDown closed");}}}

四、ComboBox的高级用法

1. 自定义项模板

通过自定义项模板,可以对

ComboBox

中的项目进行更复杂的显示和布局。

XAML代码
<ComboBoxx:Name="myComboBox"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"><ComboBox.ItemTemplate><DataTemplate><StackPanelOrientation="Horizontal"><TextBlockText="{Binding Name}"Width="100"/><TextBlockText="{Binding Description}"Width="100"/></StackPanel></DataTemplate></ComboBox.ItemTemplate></ComboBox>
后台代码
publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();this.DataContext =this;
        Items =newList<Item>{newItem{ Name ="Option 1", Description ="Description 1"},newItem{ Name ="Option 2", Description ="Description 2"},newItem{ Name ="Option 3", Description ="Description 3"}};}publicList<Item> Items {get;set;}}publicclassItem{publicstring Name {get;set;}publicstring Description {get;set;}}

在这里插入图片描述

2. 绑定复杂对象

ComboBox

的数据源为对象集合时,可以通过

DisplayMemberPath

属性指定显示对象的哪个属性。

XAML代码
<ComboBoxx:Name="myComboBox"ItemsSource="{Binding Items}"DisplayMemberPath="Name"HorizontalAlignment="Left"VerticalAlignment="Top"Width="200"/>
后台代码
publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();this.DataContext =this;
        Items =newList<Item>{newItem{ Name ="Option 1", Description ="Description 1"},newItem{ Name ="Option 2", Description ="Description 2"},newItem{ Name ="Option 3", Description ="Description 3"}};}publicList<Item> Items {get;set;}}publicclassItem{publicstring Name {get;set;}publicstring Description {get;set;}}

在这里插入图片描述

五、总结

本文详细介绍了 WPF 中

ComboBox

控件的常见属性和事件,并通过具体的示例代码展示了如何使用这些属性和事件。通过本文的学习,读者应该能够掌握

ComboBox

的基本用法,并在实际项目中灵活运用这些知识。

标签: c# wpf 学习

本文转载自: https://blog.csdn.net/weixin_56595425/article/details/139531040
版权归原作者 Ice bear433 所有, 如有侵权,请联系我们删除。

“C# WPF入门学习主线篇(九)—— ComboBox常见属性和事件”的评论:

还没有评论