6

我的datagridview itemDelete 函数:

this.dgv_items.RowsRemoved += this.dgv_items_itemDelete;

private void dgv_items_itemDelete(object sender, DataGridViewRowsRemovedEventArgs e)
{
    try
    {
        int row = e.RowIndex;
        string name = dgv_items.Rows[row].Cells[0].Value.ToString();
        deleteFromDB(name);
    }
    catch (Exception) { }
}

但是当我们到达此代码时,该行将被删除,这意味着dgv_items.Rows[row].Cells[0].Value如果行是下一行,则获取该值。

我想获取已Cells[0]删除行的值,因此我也可以从数据库文件中删除该项目。我怎样才能做到这一点?

4

2 回答 2

9

UserDeletingRow您可以改为处理该事件。请注意,它支持事件取消。

于 2012-07-16T22:37:33.843 回答
1

当您使用 RowEnter 事件选择行时,您可以将单元格的值临时保存在变量中:

private void dgv_items_RowEnter(object sender, DataGridViewCellEventArgs e)
        {
            try
            {
                // tempValue is a class var
                tempValue = dgv_items.Rows[e.RowIndex].Cells[0].Value.ToString();
            }
            catch (Exception ex) { 
                MessageBox.Show(ex.Message);
            }
        }

然后在删除之前检索 tempValue。

于 2012-07-16T22:23:29.453 回答