你的位置:首页 > ASP.net教程

[ASP.net教程]Winform开发常用控件之ComboBox、ListBox


ComboBox就是我们常见的下拉框,对于此类控件,我们最关心的当然是数据的绑定和选择值得获取。

首先介绍个属性DropDownStyle,如果不允许ComboBox输入值,只能选择,就选DropDownList,默认是DropDown。可以试一试看看效果。

1、简单的数据加载和值选取

与前面介绍的CheckBox类似,还是在items集合中设置选择项,然后取值即可,贴图和代码

 //在combobox中选择值变化中直接取选中的项,然后赋值给label    private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)    {      label1.Text = comboBox1.SelectedItem.ToString() ;    }

 //点击按钮取值,即在其他方法中取到combobox选中的值,其实一样的    private void button1_Click(object sender, EventArgs e)    {      label1.Text =comboBox1.SelectedItem.ToString();    }

从代码中可以看到,无论是comboBox自身事件取值还是其他方法中取值,都是一样的

2、ComboBox绑定数组

这个也可以用数组赋值,上代码和图

//将数组项一一添加到checkedListBox上      String[] arr = new String[] { "足球","篮球","排球"};      for (int i = 0; i < arr.Length; i++)      {        comboBox1.Items.Add(arr[i]);      }      //下面两种方法都可以为ComboBox赋初试选中值      //comboBox1.SelectedIndex = 0;      comboBox1.SelectedItem = "排球";

3、ComboBox绑定DataTable并获取选中的值

private void Form1_Load(object sender, EventArgs e)    {      //先构造一个dataTable,或者从数据库读取到一个,这里自己构造一个      DataTable dataTable = new DataTable("Student");      dataTable.Columns.Add("Number", typeof(String));      dataTable.Columns.Add("Name", typeof(String));      dataTable.Columns.Add("RealName", typeof(String));      dataTable.Columns.Add("UserName", typeof(String));      dataTable.Columns.Add("Address", typeof(String));      dataTable.Rows.Add(new String[] { "1", "James", "张三", "james.zhang", "长沙" });      dataTable.Rows.Add(new String[] { "2", "Mary", "李四", "mary.xu", "山东" });      dataTable.Rows.Add(new String[] { "3", "Jack", "王五", "jack.li", "台湾" });      dataTable.Rows.Add(new String[] { "4", "joy", "赵六", "joy.zhou", "济南" });      dataTable.Rows.Add(new String[] { "5", "jay", "钱七", "jay.ji", "美国" });      dataTable.Rows.Add(new String[] { "6", "stephen", "康忠鑫", "Stephen.Kang", "深圳" });      comboBox1.DataSource = dataTable;//绑定      comboBox1.DisplayMember = dataTable.Columns[2].ColumnName;//显示的文本      comboBox1.ValueMember = dataTable.Columns[1].ColumnName;//对应的值    }    private void button1_Click(object sender, EventArgs e)    {      //获取显示的文本和选中的值      MessageBox.Show("您选择的是" + comboBox1.GetItemText(comboBox1.Items[comboBox1.SelectedIndex]) + "|" + comboBox1.SelectedValue);    }

下面的获取方法可以获取绑定的dataTable里面的其他列值

private void button1_Click(object sender, EventArgs e)    {      //获取显示的文本和选中的值           DataRowView dr = (DataRowView)comboBox1.Items[comboBox1.SelectedIndex];      MessageBox.Show(dr[4].ToString());//根据dr的index,获取datable里面的其他值    }

这里取第四列Address

4、ComboBox绑定List,并获取值

 private void Form1_Load(object sender, EventArgs e)    {      //这里构造一个List,当然也可以从数据库中获取      IList<Student> lst = new List<Student>();      Student stu1 = new Student();      stu1.Name = "王五";      stu1.Address = "北京市";      lst.Add(stu1);      Student stu2 = new Student();      stu2.Name = "李四";      stu2.Address = "上海市";            lst.Add(stu2);      comboBox1.DataSource = lst;//绑定      comboBox1.DisplayMember = "Name";//显示的文本      comboBox1.ValueMember ="Address";//对应的值    }    private void button1_Click(object sender, EventArgs e)    {      //获取显示文本和值      MessageBox.Show("您选择的是" + comboBox1.GetItemText(comboBox1.Items[comboBox1.SelectedIndex]) + "|" + comboBox1.SelectedValue);    }

效果图

当然ComboBox还有很多种用法,比如加载带有多选框或单选按钮的列表,有感兴趣的朋友可以再研究,以后项目如果使用到偶也会贴出来的。

ListBox用法与ComboBox用法完全一样滴哦,只需将comboBox1换为listBox1即可。贴个图看看ListBox是个什么东东?

对,就是这样的,就是展示方式不一样而已。