我已经将一个数据表绑定到一个状态,这个数据表有一个名为“DataGridView”的列,它的类型是Boolean。我可以通过代码将值设置为true或false。
但是,我不知道如何检查给定行是否已被检查。这是我尝试使用的代码,编译它会显示错误“指定的类型转换无效”。
任何帮助都将不胜感激。
if (rowIndex >= 0)
{
var cbxCell = (DataGridViewCheckBoxCell)dgvScan.Rows[rowIndex].Cells["Status"];
if ((bool)cbxCell.Value)
{
// Do stuff
}
else
{
// Do other stuff
}
}发布于 2014-01-08 04:52:56
问题是DataGridCheckBoxColumn的默认FALSE值是null,而缺省TRUE值是布尔值True。这会导致一个问题,因为布尔值不能为空。有两种方法可以解决这个问题:
if (cbxCell.Value != null && (bool)cbxCell.Value)
{
do stuff;
}解决此问题的另一种方法是将列的TrueValue属性设置为某个值。这可以在设计时完成,如下所示:

然后你可以写:
if ((string)cbxCell.Value == "T")
{
do stuff;
}这是因为字符串是可以为空的。
请注意:即使我将FalseValue设置为F,False值似乎仍然是null,所以我建议忽略FalseValue属性。
另一个注意事项:如果您像上面那样将某些内容放入TrueValue,然后尝试将其擦除,则True value将变为null (糟糕),要求您删除该列,然后重新添加它,以便将其恢复为默认条件。或者您可以在代码中更改它,如下所示:
((DataGridViewCheckBoxColumn)DataGridView1.Columns["Selected"]).TrueValue = true发布于 2016-10-07 00:33:56
谢谢你们所有人。我也有同样的问题,但我发现在检查值之前编写senderGrid.EndEdit()可以解决这个问题。
private void dgvRiscos_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
var senderGrid = (DataGridView)sender;
senderGrid.EndEdit();
if (senderGrid.Columns[e.ColumnIndex] is DataGridViewCheckBoxColumn &&
e.RowIndex >= 0)
{
var cbxCell = (DataGridViewCheckBoxCell)senderGrid.Rows[e.RowIndex].Cells["associado"];
if ((bool)cbxCell.Value)
{
// Criar registo na base de dados
}
else
{
// Remover registo da base de dados
}
}
}继续做好工作
发布于 2013-11-30 14:12:34
if (Convert.ToBoolean(dgvScan.Rows[rowIndex].Cells["Status"].Value))
{
//Do Something
}
else {
// Do Something
}https://stackoverflow.com/questions/1563190
复制相似问题