0

我的 C# 应用程序中有一个数据网格视图。当我突出显示该行并点击删除时,该行将删除,但是当我运行更新和刷新命令时,我得到一个索引超出范围异常

private void btnDeleteMember_Click(object sender, EventArgs e)
{
    foreach (DataGridViewRow item in this.dgvAllFaculty.SelectedRows)
    {
        int row = item.Index;
        FacultyMember member = memberList[row];

        if (row >= 0)
        {
            memberList.RemoveAt(row);

            Save();
            this.dgvAllFaculty.Update();
            this.dgvAllFaculty.Refresh();
            return;
        }

     }
}

调试时我注意到刷新调用失败。我得到的错误是

System.IndexOutOfRangException: Index 1 does not have a value
  at System.Windows.Forms.CurrencyManager.get_Item(Int32 index)
  at
System.Windows.Forms.DataGridView.DataGridViewDataConnection.GetError(Int32 rowIndex)

如果您还有其他需要看的,请告诉我。我想知道当刷新发生时它是否疯狂,因为它仍然认为第二行在那里?

4

1 回答 1

0

好的,我稍微改变了我的代码,它现在可以工作了。在刷新之前,我必须先从 json 文件中重新加载数据。

private void btnDeleteMember_Click(object sender, EventArgs e)
    {
        int count = this.dgvAllFaculty.SelectedRows.Count;

        foreach (DataGridViewRow item in this.dgvAllFaculty.SelectedRows)
        {
            int i = item.Index;
            FacultyMember member = memberList[i];
            memberList.RemoveAt(i);
            Save();
        }

        if (count > 1)
        {
            MessageBox.Show(String.Format("{0} faculty memebers deleted", count));
        }
        else
        {
            MessageBox.Show("Faculty Member Deleted");
        }

        // Load the newest data from file before refreshing the view
        ViewAll_Load(sender, e);
        this.Refresh();
    }
于 2014-12-15T19:10:47.800 回答