我正在使用此代码:
// Cell value change event.
private void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e)
{
if ((bool)dataGridView1.CurrentCell.Value == true) MessageBox.Show("true");
if ((bool)dataGridView1.CurrentCell.Value == false) MessageBox.Show("false");
MessageBox.Show(dataGridView1.CurrentCell.Value.ToString());
}
除了一个带有复选框(DataGridViewCheckBoxColumn
)
我需要知道复选框列中的值(true或false)。
我需要做些什么呢?
答案 0 :(得分:15)
使用DataGridViewCheckBoxColumn
有时可能有点棘手,因为有些规则仅适用于此列类型的Cells
。此代码应该处理您遇到的问题。
单击单元格时,CurrentCellDirtyStateChanged
事件会立即提交更改。您在调用CellValueChanged
方法时手动引发CommitEdit
事件。
private void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e)
{
if (dataGridView1.CurrentCell == null) return;
if ((bool)dataGridView1.CurrentCell.Value == true) MessageBox.Show("true");
if ((bool)dataGridView1.CurrentCell.Value == false) MessageBox.Show("false");
MessageBox.Show(dataGridView1.CurrentCell.Value.ToString());
}
private void dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e)
{
if (dataGridView1.IsCurrentCellDirty)
{
dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);
}
}
访问here,了解有关使用DataGridViewCheckBoxCell
。
答案 1 :(得分:4)
MSDN说here在Cell失去焦点之前,CellValueChanged不会触发。
一些解决方案:
http://codingeverything.blogspot.com/2013/01/firing-datagridview-cellvaluechanged.html
答案 2 :(得分:1)
我提出了一个稍微不同的解决方案。
我使用CurrentCellDirtyStateChanged事件检查列是否为复选框列,如果是,我手动触发CellValueChanged事件,如下所示:
if (DGV_Charge.CurrentCell.ColumnIndex == 0) DGV_Charge_CellValueChanged(null, new DataGridViewCellEventArgs(DGV_Charge.CurrentCell.ColumnIndex, DGV_Charge.CurrentCell.RowIndex));
答案 3 :(得分:0)
最好是通过创建自己的网格来扩展网格,准备好这些各种“技巧”。相信我,在这个网格中需要调整很多东西。
使用
建议的代码Public Class MyGrid
Inherits Windows.Forms.DataGridView
Private Sub MyGrid_CurrentCellDirtyStateChanged(ByVal sender As Object, ByVal e As System.EventArgs) _
Handles Me.CurrentCellDirtyStateChanged
If Me.IsCurrentCellDirty AndAlso Not Me.CurrentCell Is Nothing Then
If TypeOf Me.Columns(Me.CurrentCell.ColumnIndex) Is DataGridViewCheckBoxColumn Then
Me.CommitEdit(DataGridViewDataErrorContexts.Commit) 'imediate commit, not only on focus changed
End If
End If
End Sub
Private Sub MyGrid_CellValueChanged(ByVal sender As Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs)
Handles Me.CellValueChanged
If e.RowIndex >= 0 AndAlso e.ColumnIndex >= 0 Then
Dim Checked As Boolean = False
If TypeOf Me.Columns(e.ColumnIndex) Is DataGridViewCheckBoxColumn Then
'avoid erros
Checked = Me.CellChecked(e.RowIndex, e.ColumnIndex)
End If
RaiseEvent Change(e.RowIndex, e.ColumnIndex, Checked)
End If
End Sub
End Class