DataGridView使用技巧十二:DataGridView Error图标表示的设定

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DataGridView使用技巧十二:DataGridView Error图标表示的设定相关的知识,希望对你有一定的参考价值。

为了提醒用户注意,DataGridView可以使用Error图标来突出显示。

Error图标可以在单元格和行头内表示,但不能在列头上显示。

1、ErrorText属性

当设定单元格/行的ErrorText属性的内容后,单元格/行的Error图标就会被表示出来。另外,只有在DataGridView.ShowCellErrors=True时,Error图标才能显示。(默认属性为True)

设定(0,0)的单元格表示Error图标

1 this.dgv_Users[0, 0].ErrorText = "只能输入男或女";

设定第4行的行头显示Error图标

1 this.dgv_Users.Rows[3].ErrorText = "不能输入负数";

2、CellErrorTextNeeded、RowErrorTextNeeded事件

即时输入时的Error图标的表示,可以使用CellErrorTextNeeded事件。同时,在大量的数据处理时,需要进行多处的内容检查并显示Error图标的应用中,遍历单元格设定ErrorText的方法是效率低下的,应该使用CellErrorTextNeeded事件。行的Error图标的设定则应该使用RowErrorTextNeeded事件。但是,需要注意的是当DataSource属性设定了VirtualMode=True时,上述事件则不会被触发。

CellErrorTextNeeded、RowErrorTextNeeded事件一般在需要保存数据时使用,保存数据之前先判断单元格输入的值是否合法,如果不合法,则在不合法的单元格或行显示Error图标。相当于做了一个客户端的验证。

 1 private void dgv_Users_CellErrorTextNeeded(object sender, DataGridViewCellErrorTextNeededEventArgs e)
 2 {
 3             DataGridView dgv=sender as DataGridView;
 4             
 5             if (dgv.Columns[e.ColumnIndex].Name.Equals("Sex"))
 6             {
 7                 string value = dgv[e.ColumnIndex, e.RowIndex].Value.ToString();
 8                 if (!value.Equals("") && !value.Equals(""))
 9                 {
10                     e.ErrorText = "只能输入男或女";
11                 }
12             }
13 }
1 private void dgv_Users_RowErrorTextNeeded(object sender, DataGridViewRowErrorTextNeededEventArgs e)
2 {
3             DataGridView dgv = sender as DataGridView;
4             if (dgv["UserName", e.RowIndex].Value == DBNull.Value && dgv["Password", e.RowIndex].Value == DBNull.Value)
5             {
6                 e.ErrorText = "UserName和Password列必须输入值";
7             }
8 }

 

以上是关于DataGridView使用技巧十二:DataGridView Error图标表示的设定的主要内容,如果未能解决你的问题,请参考以下文章

DataGridView使用技巧十二:DataGridView Error图标表示的设定

DataGridView 行列的隐藏和删除

Form DataGridView绑定BindingSource的几种方式

C# excel文件导入导出

C# 如何使datagridview中的单元格处于可编辑

vb中datagrid控件怎么更新?