关于DataGridViewComboBoxColumn的二三事

摘要:
但是,在“调试”中设置空值时会报告错误。弹出提示:“System.ArgumentException:列“XXX”不能设置为null。请改用DBNull……要替换此默认对话框,请处理DataError事件。”然后将值更改为DBNull。值,然后运行…搜索关键字并查找以下内容:http://blog.csdn.net/cnjack/article/details/4561376主要思想是添加DataError事件的DataGridView处理,并使处理为空以掩盖错误。再次运行时,不会报告任何错误,但无法将空值正确写入数据源。试图将空值的处理添加到DataError事件的处理中,但未成功。经过反复尝试,最终找到的解决方案是:将Text设置为非空字符串的原理未知

近日开发一个基于WinForm的工具,用到了DataGridViewComboBoxColumn。

关于数据:

  1. DataGridView的数据源是代码生成的DataTable
  2. DataGridViewComboBoxColumn的数据源是一个List<>,内容类型是自创的Text-Value类
  3. Value类型是Object,实际使用时存储的值是KeyValuePair<string,string>

问题出现:

考虑到使用时,用户会对特定项设置空值,于是在列表中加入了一个{Text = string.Empty, Value = null}的项目。

但Debug时设空值报错,弹出提示称:“System.ArgumentException: 不能将 Column "XXX" 设置为null。请改用DBNull。……要替换此默认对话框,请处理 DataError 事件。”

于是按要求把Value改成了DBNull.Value,再运行……

问题依旧!

搜索关键词,找到以下内容:

http://blog.csdn.net/cnjack/article/details/4561376

大意是添加DataGridView.DataError事件的处理,并让处理为空,以此屏蔽这个错误。

再运行,不再报错,但空值也不能正确写入数据源。看来这个方法在这里只是治标不治本。

试图在DataError事件处理中加入对空值的处理,无果。

在反复的尝试中,最终找的解决方法:

把Text设为非空字符串(不能为null或string.Empty)

原理不明……

其他注意事项:

  1. 在给DataGridView设置数据源之前,一定要先给DataGridViewComboBoxColumn设置数据源。
  2. 给DataGridViewComboBoxCell设置值时,确认该值已存在于对应DataGridViewComboBoxColumn的数据源中。

免责声明:文章转载自《关于DataGridViewComboBoxColumn的二三事》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇spark-调节executor堆外内存在网上看到这篇文章还不错,OnDrawItem与DrawItem讨论下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

快速打造 react 后台管理系统

前言我相信许多小伙伴可能会满足开发后台管理系统的要求,那么我们如何快速完成这一要求?本文将记录以React为起点创建基本管理系统模板的过程,以加深对React技术堆栈和项目实践的理解。我希望开发这样的项目对每个人都有帮助。如果文章中有错误和错误,也请看小伙伴的评论。提前感谢您的项目介绍。React admin是基于R快速创建React应用脚手架而构建的...

LaTex学习笔记(1)——LaTeX文档插入图片的几种常用方法

2,插入bmp图片还没有找到直接插入bmp图片的方法。用gimp或fastoneimageviewer,将jpg质量选为最高,转换之后得到的图片质量较好。3,同时插入jpg和eps图片插入的命令不变。编译时使用Latex,dvi2pdf,两种格式的图片都可以显示。...

beego

Charset=utf8“)56//参数4(可选)设置最大空闲连接7//参数5modelorm.RegisterModelRegisterModelWithPrefix。使用表名前缀orm.RegisterModelWithPrefixbeego自动创建表。1//参数1使用默认数据库ORM接口使用1//查询操作2funread(){3o:=ORM.NewOr...

非线性方程(组):MATLAB内置函数 solve, vpasolve, fsolve, fzero, roots [MATLAB]

MATLAB函数求解,vpsolve,fsolve,fzero,根函数和信息概述求解函数多项式型非多项式型一维高维符号数值算法求解支持,获得所有符号解如果解可以签名,当没有符号解时获得根支持符号解方法:利用方程的性质获得标准可解函数的方法基本上是模拟手动操作vpsolve支持,获取所有数值解以获得实根支持$imes$support未知fsolve从初始值获取...

谷歌浏览器插件安装、VIP看视频、解除百度网盘限速

谷歌浏览器的插件主要由石油猴子获得。为了安装油猴,您需要先安装Google Access Assistant。utm_Source=chrome ntp图标建议使用几个视频下载插件https://jingyan.baidu.com/article/49711c61b19dd5fa441b7ccd.html两个插件“百度通用网盘助手”、“网盘直链下载助手”和一...