最近开发winform项目,经常用到ComboBox控件,可能是winform做得少,数据绑定的时候,出现了一个问题,让我琢磨了好久。
问题如下:
combobox.DataSourse=oneTable;
combobox.VlueMember="ccode";//绑定oneTable中的字段
combobox.DisplayMember="ccusmer";绑定oneTable的字段
oneTable表的结构如下:
ccode ccusmer
1 one
2 two
按照常理,当你运行程序后,在Combobox控件下拉菜单中的选项应该是“one,two”,但奇怪的是显示的下拉项是“1,2”;
很奇怪。后来终于发现了原因(引用百维科技):
ComboBox的DataSource属性为object类型,但是需要实现IListSource接口的类型。
当把DataTable赋值给该属性后,如果此时没有指定ComboBox的DisplayMember和ValueMember属性的话,这时获得的ComboBox的SelectValue属性将是System.Data.DataRowView的一个实例。
据此推测DataTable中实现的IListSource接口中的GetList()方法应该返回的是DataTable的DefaultView,也就是DataView的一个实例是DataRowView的集合。
而因为没有指定DisplayMember和ValueMember属性,所以ComboBox直接把DataView中的每一个DataRowView实例填充到列表中。这样的话就可能在ComboBox的SelectedIndexChanged事件处理中产生错误。
所以:
combobox.VlueMember="ccode";//绑定oneTable中的字段
combobox.DisplayMember="ccusmer";绑定oneTable的字段
combobox.DataSourse=oneTable;
先绑定列,再绑定数据源,问题就解决了。
这时combobox.Text的值应该是“one,two”,combobox.SelectVlue的值应该是“1,2”