.NET 2.0 - WinForm Control - DataGridView 编程36计(二)

原创 2007年10月12日 11:03:00

.NET 2.0 - WinForm Control - DataGridView 编程36计(二)

目录:


① DataGridView  Error图标表示的设定:

GO TO TOP
为了提醒用户注意,DataGridView可以使用Error图标来突出显示。如下图:


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

1) ErrorText属性
当设定单元格/行的ErrorText属性的内容后,单元格/行的Error图标就会被表示出来。另外,只有在DataGridView.ShowCellErrors = True时,Error图标才能显示。(默认即时True)
[VB.NET]
' 设定 (0, 0) 的单元格表示 Error图标
DataGridView1(00).ErrorText = "请确认单元格的值。"

' 设定第4行(Index=3)的行头显示Error图标
DataGridView1.Rows(3).ErrorText = "不能输入负值。"

2) CellErrorTextNeeded、RowErrorTextNeeded 事件
即时输入时的Error图标的表示,可以使用CellErrorTextNeeded事件
同时,在大量的数据处理时,需要进行多处的内容检查并显示Error图标的应用中。遍历单元格设定ErrorText的方法是效率低下的,应该使用CellErrorTextNeeded事件。行的Error图标的设定则应该用RowErrorTextNeeded事件。
但是,需要注意的是当DataSource属性设定了VirtualMode=True时,上述事件则不会被引发。
[VB.NET]
'CellErrorTextNeeded 事件处理方法
Private Sub DataGridView1_CellErrorTextNeeded(ByVal sender As Object, _
        
ByVal e As DataGridViewCellErrorTextNeededEventArgs) _
        
Handles DataGridView1.CellErrorTextNeeded
    
Dim dgv As DataGridView = CType(sender, DataGridView)
    
' 单元格值为负整数时,Error图标被表示。
    Dim cellVal As Object = dgv(e.ColumnIndex, e.RowIndex).Value
    
If TypeOf cellVal Is Integer AndAlso CInt(cellVal) < 0 Then
        e.ErrorText 
= "不能输入负整数。"
    
End If
End Sub

'RowErrorTextNeeded 事件处理方法
Private Sub DataGridView1_RowErrorTextNeeded(ByVal sender As Object, _
        
ByVal e As DataGridViewRowErrorTextNeededEventArgs) _
        
Handles DataGridView1.RowErrorTextNeeded
    
Dim dgv As DataGridView = CType(sender, DataGridView)
    
If dgv("Column1", e.RowIndex).Value Is DBNull.Value AndAlso _
        dgv(
"Column2", e.RowIndex).Value Is DBNull.Value Then
        e.ErrorText 
= _
            
"Column1和Column2必须输入一个值。"
    
End If
End Sub

 

[C#]
// CellErrorTextNeeded 事件处理方法
private void DataGridView1_CellErrorTextNeeded(object sender,
    DataGridViewCellErrorTextNeededEventArgs e)
{
    DataGridView dgv 
= (DataGridView)sender;
    
// 单元格值为负整数时,Error图标被表示。
    object cellVal = dgv[e.ColumnIndex, e.RowIndex].Value;
    
if (cellVal is int && ((int)cellVal) < 0)
    {
        e.ErrorText 
= "不能输入负整数。";
    }
}

// RowErrorTextNeeded 事件处理方法
private void DataGridView1_RowErrorTextNeeded(object sender,
    DataGridViewRowErrorTextNeededEventArgs e)
{
    DataGridView dgv 
= (DataGridView)sender;
    
if (dgv["Column1", e.RowIndex].Value == DBNull.Value &&
        dgv[
"Column2", e.RowIndex].Value == DBNull.Value)
    {
        e.ErrorText 
= 
            
"Column1和Column2必须输入一个值。";
    }
}


 DataGridView  单元格入力值的验证:

如果想在单元格入力之后验证其入力值并在不正确的场合取消之后的动作,那么请使用事件:CellValidating。如下代码所示:当“Column1”为空的时候,则在该行设定为错误图标,并且取消之后的动作。(焦点无法离开该单元格)

[VB.NET]
'CellValidating事件处理方法
Private Sub DataGridView1_CellValidating(ByVal sender As Object, _
        
ByVal e As DataGridViewCellValidatingEventArgs) _
        
Handles DataGridView1.CellValidating
    
Dim dgv As DataGridView = CType(sender, DataGridView)

    
If dgv.Columns(e.ColumnIndex).Name = "Column1" AndAlso _
            e.FormattedValue.ToString() 
= "" Then
        
'行的错误提示的设定
        dgv.Rows(e.RowIndex).ErrorText = "值未输入"
        
'取消已经输入的内容,还原成上次的输入内容。
        'dgv.CancelEdit()
        '取消之后的动作
        e.Cancel = True
    
End If
End Sub

'CellValidated事件处理方法
Private Sub DataGridView1_CellValidated(ByVal sender As Object, _
        
ByVal e As DataGridViewCellEventArgs) _
        
Handles DataGridView1.CellValidated
    
Dim dgv As DataGridView = CType(sender, DataGridView)
    
'验证通过的话,则清空行的错误提示
    dgv.Rows(e.RowIndex).ErrorText = Nothing
End Sub

 

 DataGridView  用户输入不正确的时候的错误捕获处理

比如,数字型的列中输入不正确的值的时候处理发生错误的时候,会出现图标。但是图标表示出来,不会第一时间通知用户。

这里介绍另一种处理方式:绑定DataError事件进行处理。

 

datagridview合并表头

在form的构造函数里写下如下代码 Utility.exGridView.isEnLarged = false; 在datagridview的cellpaiting事件中写如下...
  • Tianqin20140902
  • Tianqin20140902
  • 2015年10月26日 14:25
  • 597

C#开发——winform中将Excel数据导入DataGridView

using System; using System.Data; using System.Data.OleDb; using System.Windows.Forms; namespace Exc...
  • aoanqi1990
  • aoanqi1990
  • 2014年04月14日 20:58
  • 4491

c# WinForm开发 DataGridView控件的各种操作总结(单元格操作,属性设置)

一、单元格内容的操作 *****// 取得当前单元格内容 Console.WriteLine(DataGridView1.CurrentCell.Value); // 取得当前单元格的...
  • luming666
  • luming666
  • 2016年11月16日 16:40
  • 1483

[WinForm]dataGridView动态加载以本地图片显示列

增加一个图片列: C# private void btnQuery_Click(object sender, EventArgs e) { ...
  • david_520042
  • david_520042
  • 2013年10月30日 09:19
  • 2828

C# Winform Datagridview 排序 多线程操作数据 遇到的坑

先上代码: public class BindingCollection : BindingList { protected bool isSorted; ...
  • junli110
  • junli110
  • 2017年05月19日 16:25
  • 565

关于C#WinForm的datagridview控件的使用经验及技巧收集(持续更新)

让DataGridView显示行号 在Winform窗体中选中datagridview控件,在其“RowPostPaint”触发事件属性中双击自动生成事件函数或者在右侧的下拉框中选中已写好的事件函数...
  • bestgonghuibin
  • bestgonghuibin
  • 2015年06月26日 18:11
  • 801

Winform异步解决窗体耗时操作(Action专门用于无返回值,Func专门用于有返回值)

#region 调用timer控件实时查询开关机时间 private void timer1_Tick(object sender, EventArgs e) { string sql = "...
  • config_man
  • config_man
  • 2014年05月12日 03:03
  • 3999

c#——Winform DatagridView上显示下拉树

Winform的DatagridView是不支持下拉树的,所以需要扩展 废话不多说,直接贴代码 首先需要对comBox扩展,下拉内容变成TreeView using System.Drawing...
  • Shiyaru1314
  • Shiyaru1314
  • 2016年07月15日 19:44
  • 2904

【分享】如何设计WinForm中DataGridView控件的自定义按钮列

在信息管理系统的开发过程中,我们常需要将信息显示为一个列表,并在表格的最后一列显示“查看信息”或“修改”、“删除”等按钮。在Asp.Net中我们可以采用Repeater控件方便的实现,但在WinFor...
  • SunCherryDream
  • SunCherryDream
  • 2015年06月06日 12:49
  • 2171

c# winform 关于DataGridView的一些操作(很全,绝对够用)

转自:http://heisetoufa.iteye.com/blog/405317 设置字段名 设置字段值 设定单元格表示 Error图标 设定当前单元格 取得当前单元格内容 取得当前单元格的列 ...
  • zww0815
  • zww0815
  • 2016年04月28日 16:13
  • 7530
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:.NET 2.0 - WinForm Control - DataGridView 编程36计(二)
举报原因:
原因补充:

(最多只允许输入30个字)