0

在 VB.NET WinForms 项目中,我有一个由数据集填充的 datagridview。当用户单击按钮时,我需要检查 DGV 中是否有任何新行,如果有,则获取要插入数据库的行集合。(我将 DGV 属性 AllowUserToAddRows 设置为 True,因此 DGV 底部有一行。)

我能取得任何进展的最接近的是以下,这给了我好坏参半的结果。代码确实会从新行中获取值,但前提是用户单击了新行。如果焦点没有离开新行,就好像该行没有被添加到任何幕后的新行集合中。(点击退出然后返回新行)。

If EmployeesDataSet.HasChanges(DataRowState.Modified Or DataRowState.Added) Then
    Dim changesDataSet As DataSet = EmployeesDataSet.GetChanges(DataRowState.Modified Or DataRowState.Added)
    Dim changesTable As DataTable

    For Each changesTable In changesDataSet.Tables
        Console.WriteLine("TableName: " & changesTable.TableName)
        For Each row As DataRow In changesTable.Rows
            Dim column As DataColumn
            For Each column In changesTable.Columns
                Console.Write("Value: " & row(column).ToString() & ControlChars.Tab & ", ")
            Next column
            Console.WriteLine()
        Next
    Next

End If

CaseyWilkins在这里帮助我解决了类似的问题。在这种情况下,将焦点留在更改的单元格中需要添加以下代码:

If dgvEmployees.IsCurrentCellDirty Then
    dgvEmployees.CommitEdit(DataGridViewDataErrorContexts.Commit)
End If

鉴于此,我尝试了

If dgvEmployees.IsCurrentRowDirty Then
    dgvEmployees.CommitEdit(DataGridViewDataErrorContexts.Commit)
End If

但这并没有做到。

我不能很好地包含说明“您必须单击新行才能使其工作”!:)

4

3 回答 3

1

试试这个:

dgvEmployees.CurrentCell = Nothing

这将强制 dgv 验证新的或编辑的行。在更新命令之前执行此操作。它应该工作。

于 2015-04-16T14:31:36.467 回答
0

新行可能仍处于编辑模式,因此请尝试:

dgvEmployees.EndEdit();
于 2014-11-21T00:06:15.097 回答
0

LarsTech 很接近。需要在 DataGridView 的 BindingSource 上调用 EndEdit() 方法。所以我的解决方案是

EmployeesBindingSource.EndEdit()

就在保存按钮的单击事件开始时。

我在这个页面上找到了答案。

于 2014-11-21T16:47:34.293 回答