winform 中如何得到combobox控件 Lord加载后 用户选择后 返回其选中的索引值
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了winform 中如何得到combobox控件 Lord加载后 用户选择后 返回其选中的索引值相关的知识,希望对你有一定的参考价值。
我需要这个索引值存到数据库 combobox中的选项都是我从数据库中Lord加载的
要详细点的
关于C#winForm comboBox控件的SelectedValue属性
当前comboBox有3个值
A
B
C
在Form的Load中 把数据库中读到的值赋给SelectedValue属性(使comboBox默认选中该项)
如:
数据库表'K'中有主键'ID'值为1/2/3,对应字段'Name'值为A/B/C;
外联表'L'中字有段'ID'值为1/2/3;
public void BindComboBox()
/*在winForm的Load事件中给comboBox用Items.Add()方法将表'K'的'Name'字段添入
也就是A,B,C三个值;*/
public void LoadDBValue()
/*在数据库'L'中将读到的一个值用SelectedValue显示在comboBox中*/
/*例如 读到2,则显示默认选中B*/
第二个方法的SelectedValue怎么写?
我写成这样:
//用SqlDataReader类的变量reader接收数据
int cmbValue = int.Parse(reader["id"].ToString());
comboBox.SelectedValue = cmbValue;
cmbValue值为1~3时,为什么 comboBox默认都是空白?(此时comboBox中的Items已经有A,B,C三项)
这样直接设置没有错,但是前期条件是,必须先绑定了comboBox的ValueMember属性
你可以试着选comboBox的值,然后输出一下comboBox.SelectedValue,可以发现,comboBox.SelectedValue都是null !! 参考技术A 这里直接comboBox.Text=cmbValue;就行了追问
......的确是个好方法 不过规定是用SelectedValue属性
追答winform中的下拉列表和asp。net中的下拉列表不一样。
你这样的话 在Load事件中把comboBox数据源给绑定了并设置DisplayMember和ValueMember
然后设置选中值就可以了
示例代码如下
IList tList = new List
new Testid=1,name="A",
new Testid=2,name="B",
new Testid=3,name="C"
;
comboBox1.DataSource = tList;
comboBox1.DisplayMember = "name";
comboBox1.ValueMember = "id";
comboBox1.SelectedValue = 2;
以上是关于winform 中如何得到combobox控件 Lord加载后 用户选择后 返回其选中的索引值的主要内容,如果未能解决你的问题,请参考以下文章
关于C#winForm comboBox控件的SelectedValue属性
Winform开发中如何将数据库字段绑定到ComboBox控件
如何将绑定连接到(Winform)ComboBox 控件以从绑定源获取/设置控件中的选择?