是否有任何解决方案“更新新条目后Gridview仅显示一个数据”?

时间:2019-07-08 07:11:07

标签: c# gridview

每次单击按钮时,只会显示一行。但是它应该显示多行。我在构造函数调用之后声明列表。我尝试使用gridview.update()和gridview.refresh(),但是它们不起作用。我找不到问题。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using JournalEntryApp.Model;

namespace JournalEntryApp
{
    public partial class NewDocument : Form
    {
        public NewDocument()
        {
            InitializeComponent();
        }

        List<JEFrom> JEFromsList = new List<JEFrom>();
        List<JETo> JETosList = new List<JETo>();
        JEFrom _jef = null;

        private void NewDocument_Load(object sender, EventArgs e)
        {
            label4.Text = DateTime.Now.ToString("dd-MMM-yyyy");
            using (var db =new JournalContext())
            {
                unitComboBox.DataSource = db.Units.ToList();
                unitComboBox.ValueMember = "Id";
                unitComboBox.DisplayMember = "UnitName";

            }
        }

        private void addToListButton_Click(object sender, EventArgs e)
        {

            if (string.Empty== fromAccountTextBox.Text)
            {
                MessageBox.Show("From Account can not be empty!!!");
            }
            else if (string.Empty == toAccountTextBox.Text)
            {
                MessageBox.Show("To Account can not be empty!!!");
            }
            else
            {
                _jef = new JEFrom{ FromEntryName= fromAccountTextBox.Text , FromEntryDate= DateTime.Now };
                JEFromsList.Add(_jef);
                temporaryDataGridView.DataSource = JEFromsList;

                fromAccountTextBox.Text = string.Empty;
                toAccountTextBox.Text = string.Empty;



            }

        }
    }
}

1 个答案:

答案 0 :(得分:1)

temporaryDataGridView无法检测到您已更改数据源。仅在数据源更改后才会刷新。

temporaryDataGridView.DataSource = null;
temporaryDataGridView.DataSource = JEFromsList;

因此请先将数据源更改为空。

或者您可以使用bindingSource

private void NewDocument_Load(object sender, EventArgs e)
{
    this.bindingSource1.DataSource = JEFromsList;
    temporaryDataGridView.DataSource = this.bindingSource1;

    label4.Text = DateTime.Now.ToString("dd-MMM-yyyy");
    using (var db =new JournalContext())
    {
        unitComboBox.DataSource = db.Units.ToList();
        unitComboBox.ValueMember = "Id";
        unitComboBox.DisplayMember = "UnitName";
    }
}

在button_click中

JEFromsList.Add(_jef);
bindingSource1.ResetBindings(true);