我正在使用以下代码验证DataGridView ...
void centreDataGridView_CellValidating(object sender,
DataGridViewCellValidatingEventArgs e)
{
if (centreDataGridView.Columns[e.ColumnIndex].Name == "code")
{
Regex codeRegex = new Regex("^[0-9]{5}[0-9A-Z]$");
if (!codeRegex.IsMatch(e.FormattedValue.ToString()))
{
centreDataGridView.Rows[e.RowIndex].ErrorText = "error text here";
}
}
}
void centreDataGridView_CellEndEdit(object sender,
DataGridViewCellEventArgs e)
{
centreDataGridView.Rows[e.RowIndex].ErrorText = string.Empty;
}
这是有效的,但是如果我输入新行然后再次离开它而不输入任何数据,则错误警告图标在新行选择器中仍然可见。我该如何清除它?
根据目前收到的建议,我修改了以上代码如下......
void centreDataGridView_CellValidating(object sender,
DataGridViewCellValidatingEventArgs e)
{
if (centreDataGridView.Columns[e.ColumnIndex].Name == "code")
{
if (!(centreDataGridView.Rows[e.RowIndex].IsNewRow) ||
(e.FormattedValue.ToString() != string.Empty))
{
Regex codeRegex = new Regex("^[0-9]{5}[0-9A-Z]$");
if (!codeRegex.IsMatch(e.FormattedValue.ToString()))
{
centreDataGridView.Rows[e.RowIndex].ErrorText = "error text here";
}
}
}
}
这确实解决了在没有输入数据时在新行旁边显示错误指示符的问题。但是,当我输入无效数据时,在任何行中,当我在输入无效数据后第一次离开行时,没有显示错误指示符。如果我使用无效数据离开行,然后返回到该行,然后再将其移开,然后显示错误指示符。
答案 0 :(得分:3)
好的,我相信我现在已经得到了。我将ErrorText设置为CellValidating事件处理程序开头的空字符串,而不是CellEndEdit事件处理程序中的空字符串,如下所示。这基本上是收到的所有建议的组合,所以感谢大家,这一切都很有帮助。
void centreDataGridView_CellValidating(object sender,
DataGridViewCellValidatingEventArgs e)
{
centreDataGridView.Rows[e.RowIndex].ErrorText = string.Empty;
if (centreDataGridView.Columns[e.ColumnIndex].Name == "code")
{
if (!(centreDataGridView.Rows[e.RowIndex].IsNewRow) ||
(e.FormattedValue.ToString() != string.Empty))
{
Regex codeRegex = new Regex("^[0-9]{5}[0-9A-Z]$");
if (!codeRegex.IsMatch(e.FormattedValue.ToString()))
{
centreDataGridView.Rows[e.RowIndex].ErrorText = "blah blah blah";
}
}
}
}
答案 1 :(得分:0)
添加检查已验证的行是否为NewRow
,如果是,则返回。
void centreDataGridView_CellValidating(object sender, DataGridViewCellValidatingEventArgs e)
{
if (centreDataGridView.Rows[e.RowIndex].IsNewRow)
{
return; // do not validate row that has no values
}
if (centreDataGridView.Columns[e.ColumnIndex].Name == "code")
{
Regex codeRegex = new Regex("^[0-9]{5}[0-9A-Z]$");
if (!codeRegex.IsMatch(e.FormattedValue.ToString()))
{
centreDataGridView.Rows[e.RowIndex].ErrorText = "error text here";
}
}
}