继续聊WPF——获取ComboBox中绑定的值

本文详细解析了WPF中数据绑定的原理及其与Winform程序的区别,着重介绍了ComboBox控件的数据绑定实现,通过创建Employee类、EmployeeArr列表以及XAML界面,演示了如何使用DisplayMemberPath和SelectedValuePath属性进行数据绑定,并展示了实时更新功能的运用,最终通过按钮点击事件验证了绑定效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

千万不要认为WPF中的数据绑定会很复杂,尽管它的确比Winform程序灵活多了,但其本质是不变的,特别是ComboBox控件,我们知道在Winform中对该控件的有两个专为数据绑定而设定的属性——DisplayMenber和ValueMenber,分别绑定用于显示和用于存放用户选择值两个字段,最典型的应用类似于key-value形式的数据字段,如学生表中的学号(ID)和学生姓名。

其实,在WPF中原理都是一样的,来,我们一起动手玩玩。

如何新建应用程序就不用介绍了,省略33个字。

在窗口中拖放一个ComboBox控件和一个按钮,按钮用来检测所选择的值。

图片

切换到代码视图,定义一个Employee类和一个列表。

 public class Employee
 {
  public string Name{set;get;}
  public int EmpID{ set;get; }
 }

 

    public class EmployeeArr : ObservableCollection<Employee>
    {
        public EmployeeArr()
        {
            this.Add(new Employee { EmpID = 1, Name = "林鸟" });
            this.Add(new Employee { EmpID = 2, Name = "小胡" });
            this.Add(new Employee { EmpID = 3, Name = "小字" });
            this.Add(new Employee { EmpID = 4, Name = "小牛X" });
            this.Add(new Employee { EmpID = 5, Name = "王狗" });
        }
    }


然后在XAML中加入资源列表中

<Window
 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 x:Class="ComboBox_Binding_sample.MainWindow"
 x:Name="Window"
 Title="MainWindow"
 Width="200" Height="120"
    xmlns:c="clr-namespace:ComboBox_Binding_sample">
    
    <Window.Resources>
        <c:EmployeeArr x:Key="EmpCols"/>
    </Window.Resources>
 .......

</Window>


然后,把ComboBox绑定到资源中的集合。

  <ComboBox x:Name="cmb" Margin="8,8,8,7.04" ItemsSource="{StaticResource EmpCols}"
                  DisplayMemberPath="Name"
                  SelectedValuePath="EmpID"/>
  <Button Margin="28,6,28,6" Content="显示选定的值" Grid.Row="1"
                Click="Button_Click"/>


最后完成按钮的单击事件

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            if (this.cmb.SelectedIndex != -1)
            {
                MessageBox.Show("你选择的员工编号为:\n" +
                    cmb.SelectedValue);
            }
        }


运行一下就能得到效果了。

图片

图片

前文中刚讨论完依赖项属性,我们不妨这里也用上它的实时更新功能。

<Window x:Class="ComboBox_Binding_sample.W02"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="W02" Height="130" Width="270"
    xmlns:c="clr-namespace:ComboBox_Binding_sample">
    <Window.Resources>
        <c:EmployeeArr x:Key="ec"/>
    </Window.Resources>
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="*"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>
        <ComboBox x:Name="cmb" Grid.Row="0" Margin="10,8,10,8" ItemsSource="{StaticResource ec}"
                  DisplayMemberPath="Name" SelectedValuePath="EmpID"/>
        <TextBlock Grid.Row="1" VerticalAlignment="Center" FontSize="18"
                   HorizontalAlignment="Center"
                   Text="{Binding ElementName=cmb,Path=SelectedValue}"/>
    </Grid>
</Window>


这样,只要我们选择的项改变,文本块中就会实时显示员工ID。

图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值