(转)Combobox出现System.Data.DataRowView的原因,以及指定ValueMember的时机问题
原文地址 http://blog.csdn.net/lubiaopan/article/details/5915774
当使用Combobox控件时,出现SelectedValue的值为“System.Data.DataRowView”的原因有两个:在Combobox的DataSource不为空的情况下,要么是没有为ValueMember赋值,要么是赋值赋错了,这两种情况下系统就会把SelectedValue的默认值输出来(注意红色部分,如果DataSource为空,那么SelectedValue的值为null)。但有时即使你对ValueMember赋了正确的值也会出现这个问题,这里有一个赋值时机选择的问题,请看下面的示例:
首先,构造如下所示的一个窗体:
窗体有一个下拉框,名为Combobox1,还有一个文本框,名为TextBox1,功能很简单,当选择下拉框的某一项的时候,把该选择项对应的ValueMember的值显示到文本框中。下面是实现该功能的核心代码:
Code-1:
- namespace FrmForTest
- {
- public partial class Form1 : Form
- {
- public Form1()
- {
- InitializeComponent();
- this.InitialCombobox();
- }
- private void InitialCombobox()
- {
- DataTable table = new DataTable();
- DataColumn column;
- DataRow row;
- column = new DataColumn("Name");
- table.Columns.Add(column);
- column = new DataColumn("Value");
- table.Columns.Add(column);
- for (int i = 0; i < 5; i++)
- {
- row = table.NewRow();
- row["Name"] = "Test" + i;
- row["Value"] = i.ToString();
- table.Rows.Add(row);
- }
- this.comboBox1.DataSource = table;
- this.comboBox1.DisplayMember = "Name";
- this.comboBox1.ValueMember = "Value";
- }
- private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
- {
- this.textBox1.Text = this.comboBox1.SelectedValue.ToString();
- }
- }
- }
运行上面的代码,窗体初始化完毕后输出的结果如下:
文本框显示的是“System.Data.DataRowView”,前面说过,只有在没有为Combobox指定ValueMember的值或指定错的情况下才会是该字符串,可程序已经正确指定了ValueMember为什么还是这个结果呢?我试着选择其他的下拉项,发现显示的结果变成了预想的值,原因何在?
仔细观察程序发现原因在于ValueMember赋值的时机,上面的代码当执行完DataSource赋值语句之后,触发了SelectedIndexChanged事件,而此时还未指定ValueMember,所以窗体初次初始化后显示的是“System.Data.DataRowView”,解决方法很简单:只需把DataSource赋值语句放到DisplayMember、ValueMember语句之后。
好,这个问题解决了,新的问题又来了,请看下面的描述:
突然想到Combobox还有一个事件是SelectedValueChanged,还是上面的程序Code-1,把SelectedIndexChanged替换为SelectedValueChanged,会是什么效果呢?试了一下,没有报错,并且窗体初始化完毕后显示的就是预期的值0。呵呵,又找到了一种解决方法。问题还没完,请接着往下看:
上面SelectedValueChanged的试验中,DataSource是在DisplayMember、ValueMember前面的,如果放到它们两个后面呢?继续尝试,这次报错了——“未将对象引用到对象的示例”,对程序进行跟踪,当执行完this.comboBox1.ValueMember = "Value"语句之后,程序转到了comboBox1_SelectedIndexChanged方法,在this.textBox1.Text = this.comboBox1.SelectedValue.ToString();语句处报错,SelectedValue的值为空,因为此时还没有给DataSource赋值,所以报这个错。
现在可以总结了,当使用SelectedIndexChanged时,ValueMember在DataSource前进行赋值,当使用SelectedValueChanged时,ValueMember在DataSource后进行赋值。
还有一个问题很有意思,如下所示:
this.comboBox1.DisplayMember = "Name";
this.comboBox1.ValueMember = "ValueError";
this.comboBox1.DataSource = table;
上面故意把ValueMember的值写错了,运行起来没有任何问题(是指没有报错,此时的SelectedValue值都为System.Data.DataRowView),然后我们对这三行代码的顺序做一下调整,如下:
this.comboBox1.DataSource = table;
this.comboBox1.DisplayMember = "Name";
this.comboBox1.ValueMember = "ValueError";
上面ValueMember的值依旧是错的,但是对其赋值操作放到了DataSource语句之后,运行程序,在ValueMember赋值语句处报错如下:“无法绑定到值成员”。
当指定了DataSource的值后再对ValueMember赋错,如果此时赋值赋错的话,运行时就会报错,如果是在DataSource语句之前对ValueMember赋值则不会报错,大家在应用的时候一定要注意。
(转)Combobox出现System.Data.DataRowView的原因,以及指定ValueMember的时机问题的更多相关文章
- Combobox出现System.Data.DataRowView的原因
这种情况多次遇到.有时候明明完全相同的代码,在不同的场景运行却是两种结果, 其中一种坏的结果就是 comboBox所有的项都显示为System.Data.DataRowView 今天仔研究了一下,应该 ...
- winform Combobox出现System.Data.DataRowView的解决的方法
个人总结: 1.触发了SelectedIndexChanged事件时:comboBox1.DataSource = dt;要放在comboBox1.SelectedIndex = 0;的上面 comb ...
- comboBox的id返回System.Data.DataRowView
关系到ComboBox的DataSource,DisplayMember和ValueMember属性的设置顺序的问题. ComboBox的DataSource属性为object类型,但是需要实现ILi ...
- 也谈解决Combobox绑定数据后取值出现System.Data.DataRowView的问题
刚才遇到一个怪现象:同一个窗口,同一张表,通过第一个Combobox值的改变,动态绑定第二个Combobox,结果出现一个怪现象,第一个Combobox有的值改变第二个Combobox一切正常,有几个 ...
- DropdownList控件绑定数据源显示system.data.datarowview的问题
.net开发的时候经常需要用到在后台取数据再绑定到控件的问题,通常只需要连接数据库,从数据库取出数据,放到Dataset里面,然后再设置控件的DataSource为这个Dataset,然后再datab ...
- System.Data.SQLite.dll控件常规安装方法
原文地址:http://www.jb51.net/dll/System.Data.SQLite.dll.html 文件运行必须安装 Microsoft Visual C++ 2010 SP1 Re ...
- SharePoint "System.Data.SqlClient.SqlException (0x80131904): Parameter '@someColumn' was supplied multiple times.“
最近在处理SharePoint Office365的相关开发的时候发现了这样一个奇怪的现象: 无法通过API更新Editor field,只要已更新就会throw Exception,由于是Offic ...
- 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用
学习 EF Code First+MVC 时遇到了在请求JsonResult时出现 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用 的异常,原因 ...
- IIS发布网站出现“未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项。”的解决方法
未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项.试图加载格式不正确的程序. 说明: 执行当前 Web 请求期间,出现未经处理的异常.请检查堆栈 ...
随机推荐
- C# ASP.NET基类,常用类库及源代码
http://code1.okbase.net/codefile/SerializeHelper.cs_2012122018724_118.htm
- com.opensymphony.module.sitemesh.filter.PageFilter 装饰页面
1.web.xml中配置: <filter> <filter-name>sitemeshFilter</filter-name> <filter-class& ...
- Entity Framework菜鸟初飞
Entity Framework菜鸟初飞 http://blog.csdn.net/zezhi821/article/details/7235134
- [Hibernate] - Load and Get
Hibernate中使用session的load(...)和get(...)区别: 1.load()方法是在返回的类被后期调用时,才会去提交SQL查询数据库. 2.get()方法是在调用get()时就 ...
- 重绘Winform窗体
本文转载自:http://www.cnblogs.com/encoding/p/5603080.html 按照惯例,先来几张样例图(注:为了展示窗口阴影效果,截图范围向外扩展了些,各位凭想象吧). 还 ...
- 如何重装air
参考这里 很多年没有装过系统了,手贱用xxcleaner清理了下,好吧,我觉得只能重装了,直接贴过程吧 ,开机同时command+R,进入菜单 ,抹掉磁盘 ,重启,等在线更新(看各位运气了,网速好的话 ...
- SqlServer统计最近一周的数据
select * from 表名 where DATEDIFF( day, 日期字段列名,getdate())<7 and DATEPART(w, 日期字段列名) <DATEPART( ...
- .NET简谈插件系统开发模式
摘选自[王清培]博客 http://www.cnblogs.com/wangiqngpei557/archive/2011/06/10/2077413.html 今天跟大家分享一下我们在日常开发中并不 ...
- 黄聪:使用WORDPRESS自带AJAX方法
例如给网站每页logo后面的一句名言,点击“换一条”就会ajax动态加载一条,使用了wordpress的自带ajax方法.下面介绍如何使用wordpress自带ajax方法: 1.在header.ph ...
- codeblocks AStyle修改格式和快捷键
首先我想说 codeblocks还是很强大的,原来以为不能改,其实是不会,那么本篇博客就教大家修改AStyle格式和添加快捷键. 1.修改AStyle格式: Settings -> Editor ...