0
点赞
收藏
分享

微信扫一扫

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


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


目录:

  • ① Error图标表示的设定
  • ②   单元格入力值得验证


① DataGridView  Error图标表示的设定:



GO TO TOP

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


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



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



1) ErrorText属性

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

[VB.NET]

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


DataGridView1(
0
,
0
).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

举报

相关推荐

0 条评论