DataGridView.IsCurrentCellDirty 속성

정의

현재 셀에 커밋되지 않은 변경 내용이 있는지 여부를 나타내는 값을 가져옵니다.Gets a value indicating whether the current cell has uncommitted changes.

public:
 property bool IsCurrentCellDirty { bool get(); };
[System.ComponentModel.Browsable(false)]
public bool IsCurrentCellDirty { get; }
member this.IsCurrentCellDirty : bool
Public ReadOnly Property IsCurrentCellDirty As Boolean

속성 값

현재 셀에 커밋되지 않은 변경 내용이 있으면 true이고, 그렇지 않으면 false입니다.true if the current cell has uncommitted changes; otherwise, false.

특성

예제

다음 코드 예제에서는 IsCurrentCellDirty 셀 값을 커밋하고 발생 여부를 결정 하는 속성을 CellValueChanged 에 대 한 처리기에서 이벤트를 CurrentCellDirtyStateChanged 이벤트입니다.The following code example uses the IsCurrentCellDirty property to determine whether to commit a cell value and raise the CellValueChanged event from a handler for the CurrentCellDirtyStateChanged event. 이 코드 예제는 에서 제공 하는 보다 큰 예제의 일부입니다. Windows Forms DataGridView 컨트롤의 단추 열에서 단추를 비활성화 합니다.This code example is part of a larger example provided in How to: Disable Buttons in a Button Column in the Windows Forms DataGridView Control.

// This event handler manually raises the CellValueChanged event
// by calling the CommitEdit method.
void dataGridView1_CurrentCellDirtyStateChanged(object sender,
    EventArgs e)
{
    if (dataGridView1.IsCurrentCellDirty)
    {
        dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);
    }
}

// If a check box cell is clicked, this event handler disables  
// or enables the button in the same row as the clicked cell.
public void dataGridView1_CellValueChanged(object sender,
    DataGridViewCellEventArgs e)
{
    if (dataGridView1.Columns[e.ColumnIndex].Name == "CheckBoxes")
    {
        DataGridViewDisableButtonCell buttonCell =
            (DataGridViewDisableButtonCell)dataGridView1.
            Rows[e.RowIndex].Cells["Buttons"];

        DataGridViewCheckBoxCell checkCell =
            (DataGridViewCheckBoxCell)dataGridView1.
            Rows[e.RowIndex].Cells["CheckBoxes"];
        buttonCell.Enabled = !(Boolean)checkCell.Value;

        dataGridView1.Invalidate();
    }
}
' This event handler manually raises the CellValueChanged event
' by calling the CommitEdit method.
Sub dataGridView1_CurrentCellDirtyStateChanged( _
    ByVal sender As Object, ByVal e As EventArgs) _
    Handles dataGridView1.CurrentCellDirtyStateChanged

    If dataGridView1.IsCurrentCellDirty Then
        dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit)
    End If
End Sub

' If a check box cell is clicked, this event handler disables  
' or enables the button in the same row as the clicked cell.
Public Sub dataGridView1_CellValueChanged(ByVal sender As Object, _
    ByVal e As DataGridViewCellEventArgs) _
    Handles dataGridView1.CellValueChanged

    If dataGridView1.Columns(e.ColumnIndex).Name = "CheckBoxes" Then
        Dim buttonCell As DataGridViewDisableButtonCell = _
            CType(dataGridView1.Rows(e.RowIndex).Cells("Buttons"), _
            DataGridViewDisableButtonCell)

        Dim checkCell As DataGridViewCheckBoxCell = _
            CType(dataGridView1.Rows(e.RowIndex).Cells("CheckBoxes"), _
            DataGridViewCheckBoxCell)
        buttonCell.Enabled = Not CType(checkCell.Value, [Boolean])

        dataGridView1.Invalidate()
    End If
End Sub

설명

경우는 DataGridView 바인딩되지 않은 데이터를 셀 편집 커밋된 것으로 간주 창의 다른 셀으로 이동할 때.When the DataGridView is not bound to data, the cell edit is considered committed when the user moves to another cell.

행 머리글이 표시 되 면 연필 문자 모양을 커밋되지 않은 변경 내용이 있는 셀이 포함 된 행 헤더에 제공 됩니다.If row headers are visible, a pencil glyph is present in the header for the row that contains a cell with uncommitted changes.

하는 경우 IsCurrentCellDirty 됩니다 true 는 편집 컨트롤을 호스트 하는 현재 셀을 통해 검색할 수 있습니다는 EditingControl 속성입니다.If IsCurrentCellDirty is true and the current cell hosts an editing control, you can retrieve it through the EditingControl property.

적용 대상

추가 정보