仅在关闭和打开对话框后更新数据库

时间:2019-02-26 11:12:03

标签: c# .net datagridview

我在窗体中有一个DataGridView,每次加载这样的页面时,该窗体都会显示数据库中的数据:

private void LoadList(string Input)
{
    fieldsDataGridView.DataSource = null;
    List<Field> fields = new List<Field>();
    fields = fieldsData.GetAllByTaskId(Input);
    List<FieldsDGViewModel> fdgvm = new List<FieldsDGViewModel>();
    foreach (var item in fields)
    {
        var f = new FieldsDGViewModel
        {
            Id = item.Id,
            Name = item.Name,
            Order = item.Order,
            IsPrint = item.IsPrint
        };
        fdgvm.Add(f);
    }
    fdgvm = fdgvm.OrderBy(x => x.Order).ToList();
    fieldsDataGridView.DataSource = fdgvm;
    fieldsDataGridView.SelectionMode = DataGridViewSelectionMode.FullRowSelect;
    fieldsDataGridView.Columns["Id"].Visible = false;
    fieldsDataGridView.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
}

当我双击列表中的一个条目时,它会打开一个包含表单的对话框,并从该条目中加载相应的详细信息。当我保存详细信息时,对话框关闭,并且在我的DataGridView所在的类中,有一个FormClose函数可以刷新DataGridView。

private void FormClosed(object sender, FormClosedEventArgs e)
{
    RefreshDataGrid();
    RecursiveClearInputs(this.Controls);
    fieldIdInput.Text = "";
}

private void RefreshDataGrid()
{
    var selected = programInput.SelectedValue;
    if (selected != null)
    {
        var result = programsData.Get(selected.ToString());
        if (result != null)
        {
            programIdInput.Text = result.Id;
            LoadList(result.Id);
        }
    }
    if (selected == "-1")
    {
        RecursiveClearInputs(this.Controls);
        programIdInput.Text = "";
        fieldIdInput.Text = "";
        fieldsDataGridView.DataSource = null;
    }
    fieldsDataGridView.ClearSelection();
}

但是,我遇到的问题是,正确刷新DataGridView的唯一方法是关闭我所打开的主窗体,然后再次将其重新打开。

我调试并设法捕获了一些结果。

Image1:紧接在Update窗体之后。在字段列表中,只有一个条目可以具有IsPrint = true。但是图像显示两者都是正确的。

enter image description here

Image2:关闭并重新打开包含DataGridView的页面后,它显示此正确结果。只有1 IsPrint = true。

enter image description here

我尝试了许多方法来解决此问题,但是我不确定为什么它无法正确刷新。

这就是我打开对话框的方式

EditFields editFields = new EditFields(programIdInput.Text, fieldIdInput.Text, false);
editFields.FormClosed += new FormClosedEventHandler(FormClosed);
editFields.ShowDialog();

编辑:

我添加了一个dialogresult检查,但是它仍然不能正确更新datagridview。也许是线程问题?

dr = editFields.ShowDialog();
if (dr == DialogResult.OK)
{
    RefreshDataGrid();
    RecursiveClearInputs(this.Controls);
    fieldIdInput.Text = "";
}

2 个答案:

答案 0 :(得分:0)

我只是假设OnCklick事件在打开Dialog时的外观,但我认为问题在于您试图通过另一个Form / Thread刷新Datagrid。 (不起作用)

我建议您使用ShowDialog打开对话框窗体,并在onclick事件本身中关闭窗体后刷新网格。尝试更换

RefreshDataGrid();

在您的FormClosed事件中使用

DialogResult = DialogResult.OK;

然后,您就可以像这样在onclick事件中处理网格重新加载:

 EditFields editFields = new EditFields(programIdInput.Text, fieldIdInput.Text, false);

   if (editFields.ShowDialog(this) == DialogResult.OK)
   {
          RefreshDataGrid();
   }
   else
   {
     //it was canceled
   }
   editFields.Dispose();

答案 1 :(得分:-1)

您需要将主表单传递给详细表单。
在详细信息表中,实现OnClosingOnClosed事件并调用MainForm.LoadList()