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


      转自:http://blog.csdn.net/fangxinggood/archive/2007/10/12/1821425.aspx

    .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
    antony
    :antony1029@163.com
    :http://antony1029.cnblogs.com
  • 相关阅读:
    python内置模块collections介绍
    Python的set集合详解
    不同 Python 数据类型的搜寻
    Python 分支、循环、条件与枚举
    ssrf爆破mysql
    php反序列化
    thinkphp历史漏洞
    Thinkphp 缓存RCE
    绕WAF文章收集
    mssql手工盲注
  • 原文地址:https://www.cnblogs.com/antony1029/p/1347131.html
Copyright © 2020-2023  润新知