当前位置: 首页 > 工具软件 > comboBox > 使用案例 >

WPF ComboBox

夏侯英纵
2023-12-01

ComboBox 控件在很多方面都类似于 ListBox 控件,但占用的空间要少得多,因为项目列表在不需要时会隐藏起来。ComboBox 控件在 Windows 中的很多地方都有使用,但为了确保每个人都知道它的外观和工作方式,我们将直接进入一个简单的示例:

<Window x:Class="WpfTutorialSamples.ComboBox_control.ComboBoxSample"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="ComboBoxSample" Height="150" Width="200">
    <StackPanel Margin="10">
        <ComboBox>
            <ComboBoxItem>ComboBox Item #1</ComboBoxItem>
            <ComboBoxItem IsSelected="True">ComboBox Item #2</ComboBoxItem>
            <ComboBoxItem>ComboBox Item #3</ComboBoxItem>
        </ComboBox>
    </StackPanel>
</Window>

一、用字典给ItemsSource赋值

XMAL

<ComboBox Name="cmb_list" Grid.Row="1" Grid.Column="1" Height="23" DisplayMemberPath="Value" SelectedValuePath="Key" SelectionChanged="cmb1_SelectionChanged"></ComboBox>

CS文件、


```csharp
private void BindData()

{undefined

Dictionary<int, string> dicItem = new Dictionary<int, string>();
dicItem.add(1,"北京");

dicItem.add(2,"上海");

dicItem.add(3,"广州");

cmb_list.ItemsSource =dicItem;

cmb_list.SelectIndex=0;

}

二、XAML 中直接绑定(此绑定很不实用)

<TextBlock VerticalAlignment="Center">直接在XAML中绑定数据</TextBlock>
        <ComboBox Grid.Column="1" Height="23" Name="cmb1" SelectionChanged="cmb1_SelectionChanged">
            <ComboBoxItem Content="上海" Tag="1"></ComboBoxItem>
            <ComboBoxItem Content="北京" Tag="2"></ComboBoxItem>
            <ComboBoxItem Content="天津" Tag="3"></ComboBoxItem>
        </ComboBox>

此绑定 不能设置 SelectValue 值
SelectedItem 返回的是 System.Windows.Controls.ComboBoxItem:上海

SelectedValue 返回的是 System.Windows.Controls.ComboBoxItem:上海

Text 返回的才是 显示的值。

如果想和Winform 中的获取 Value的值。可以 实用 Tag 属性。Tag为 Object 类型。可以获取Value值。

三、绑定IList集合属性 (此绑定比较实用 本人比较喜欢)

 public class City 
    {
        public int ID { get; set; }
        public string Name { get; set; }
    }
 private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            List<City> list = new List<City>();
            list.Add(new City { ID = 1, Name = "上海" });
            list.Add(new City { ID = 2, Name = "北京" });
            list.Add(new City { ID =3, Name = "天津" });
            cmb_list.ItemsSource = list;
           
        }
  <ComboBox Name="cmb_list" Grid.Row="1" Grid.Column="1" Height="23"
                  DisplayMemberPath="Name" SelectedValuePath="ID" SelectionChanged="cmb1_SelectionChanged"></ComboBox>

如果不设置 此 DisplayMemberPath=“Name” 属性。 ComboBox 显示的是 City 类型名 (City没有覆盖ToString()方法)。如果City覆盖ToString()方法。将显示的是

ToString()方法返回的字符串信息。

注意:切记 要设置 DisplayMemberPath=“Name” 属性

设置 SelectedValuePath="ID"属性。如果City覆盖了 ToString()方法。

SelectItem ToString() 返回 City ToString()返回的内容。

SelectValue ToString() 为 City 中ID的值。

四、 绑定DataTable

 private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add(new DataColumn("ID", typeof(Int32)));
            dt.Columns.Add(new DataColumn("Name", typeof(string)));

            DataRow dr1 = dt.NewRow();
            dr1["ID"] = 1;
            dr1["Name"] = "上海";
            dt.Rows.Add(dr1);
            dt.Rows.Add(2, "北京");
            dt.Rows.Add(3,"天津");

            cmb_list.ItemsSource =dt.DefaultView; 
        }
  <ComboBox Name="cmb_list" Grid.Row="1" Grid.Column="1" Height="23"
                  DisplayMemberPath="Name" SelectionChanged="cmb1_SelectionChanged"></ComboBox>
  1. ComboBox:下拉列表框
    效果如下:

2.通常用法是 显示内容 + 选中内容后获得的值(也就是 Name = Value的键值对)
故以键值对来定义一个类,如:

public class CategoryInfo
{
    public string Name { get; set;}
    public string Value{ get; set;}
}
  1. 再使用 List来存储这些选项的集合
    List categoryList = new List();
categoryList.Add(new CategoryInfo{Name="English", Value="en_US"});//英语
categoryList.Add(new CategoryInfo{Name="中文", Value="zh_CN"});//中文
categoryList.Add(new CategoryInfo{Name="日本語", Value="ja_JP"});//日语
  1. 通过ItemSource给ComboBox绑定数据 
    comboType.ItemsSource = categoryList;
    //这里的Name和Value不能乱填哦
    comboType.DisplayMemberPath = “Name”;//显示出来的值
    comboType.SelectedValuePath = “Value”;//实际选中后获取的结果的值

5.代码中处理选中的值

 private void Button_Click(object sender, RoutedEventArgs e)
{
       //如显示的是English,这里的SelectedValue的值就是en_US
        string langName = cbLang.SelectedValue.ToString();
}
 类似资料:

相关阅读

相关文章

相关问答