在 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
但这并没有做到。
我不能很好地包含说明“您必须单击新行才能使其工作”!:)