DataGridView使用技巧十二:DataGridView Error图标表示的设定
2024-09-28 14:12:39
为了提醒用户注意,DataGridView可以使用Error图标来突出显示。
Error图标可以在单元格和行头内表示,但不能在列头上显示。
1、ErrorText属性
当设定单元格/行的ErrorText属性的内容后,单元格/行的Error图标就会被表示出来。另外,只有在DataGridView.ShowCellErrors=True时,Error图标才能显示。(默认属性为True)
设定(0,0)的单元格表示Error图标
this.dgv_Users[, ].ErrorText = "只能输入男或女";
设定第4行的行头显示Error图标
this.dgv_Users.Rows[].ErrorText = "不能输入负数";
2、CellErrorTextNeeded、RowErrorTextNeeded事件
即时输入时的Error图标的表示,可以使用CellErrorTextNeeded事件。同时,在大量的数据处理时,需要进行多处的内容检查并显示Error图标的应用中,遍历单元格设定ErrorText的方法是效率低下的,应该使用CellErrorTextNeeded事件。行的Error图标的设定则应该使用RowErrorTextNeeded事件。但是,需要注意的是当DataSource属性设定了VirtualMode=True时,上述事件则不会被触发。
CellErrorTextNeeded、RowErrorTextNeeded事件一般在需要保存数据时使用,保存数据之前先判断单元格输入的值是否合法,如果不合法,则在不合法的单元格或行显示Error图标。相当于做了一个客户端的验证。
private void dgv_Users_CellErrorTextNeeded(object sender, DataGridViewCellErrorTextNeededEventArgs e)
{
DataGridView dgv=sender as DataGridView; if (dgv.Columns[e.ColumnIndex].Name.Equals("Sex"))
{
string value = dgv[e.ColumnIndex, e.RowIndex].Value.ToString();
if (!value.Equals("男") && !value.Equals("女"))
{
e.ErrorText = "只能输入男或女";
}
}
}
private void dgv_Users_RowErrorTextNeeded(object sender, DataGridViewRowErrorTextNeededEventArgs e)
{
DataGridView dgv = sender as DataGridView;
if (dgv["UserName", e.RowIndex].Value == DBNull.Value && dgv["Password", e.RowIndex].Value == DBNull.Value)
{
e.ErrorText = "UserName和Password列必须输入值";
}
}
最新文章
- 终端mysql Operation not permitted错误解决方案
- RUDP之一 —— UDP VS TCP
- [经验] 新版SkyIAR、Easy Image X在有些PE里不能运行的解决办法
- (转载)linux中设备文件配置程序udev详解
- c#新手之1-如何组织类及相互调用
- win7 64位系统下 PL/SQL无法连接的问题
- EXTJS4.2 chart 柱状图
- python的sorted相关
- Spring、编码剖析Spring管理Bean的原理
- 使用BeautifulSoup解析XML文档
- Linux 中环境变量设置
- rename.go
- 使用jquery实现选项卡切换效果
- Spring boot+Thymeleaf+easyui集成:js创建组件页面报错
- Echart数据转换(水平数据变成垂直数据)
- 关于C语言头文件写法的探讨
- Visual Studio 2010 Express for Windows Phone 永久免费序列号
- 关于altera fpga的io时序优化问题
- Oracle11g的服务
- ubuntu16.04 opencv3.4.1 opencv-contribute3.4.1 compile
热门文章
- Windows2008R2允许多用户远程登录设置
- C# 读写网上邻居中的共享文件
- C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序
- Ubuntu 10.04 安装流程
- Selenium-Grid工作原理
- Android 自定义属性动画&;Camera动画
- php 解析xml
- 跟我一起学习VIM - vim插件合集
- php短域名转为实际域名的函数参考
- JS 中document.URL 和 windows.location.href 的区别