获取已移除的DataGridView行的单元格值

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]值,以便我也可以从数据库文件中删除该项。我应该如何实现这个?

1
顺便说一句,你应该删除那个 try/catch 块。如果有问题,你永远不会知道它是什么。 - John Saunders
@JohnSaunders 抱歉标题不太好,我很累了。我知道try/catch块可能会有问题,但这个程序是为了快速个人使用,所以我现在并不关心。但我同意这是不好的做法。 - natli
1
你尝试过UserDeletingRow事件吗?(还支持事件取消) - Luis Quijada
1
@LuisQuijada 天才!那个方法可行!虽然我不能像这样选择它作为答案。不过还是谢谢你;D - natli
2个回答

9
您可以处理 UserDeletingRow 事件来代替。请注意,它支持事件取消。

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。


很有创意,我喜欢。这个方法可能有效,但正如Luis所建议的那样,UserDeletingRow事件是唯一合乎逻辑的解决方案。不过还是谢谢你:D - natli
2
提醒:仅显示或记录“ex.Message”是不良实践。应使用“ex.ToString()”,因为它会显示完整的异常以及堆栈跟踪和任何内部异常。 - John Saunders

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接