8

这是我的代码(这是一个非常简单的例子):

public partial class Form1 : Form
{
    List<Person> listPersons;
    public Form1()
    {
        InitializeComponent();
        listPersons = new List<Person>();
        dataGridView1.DataSource = listPersons;
    }

    private void button1_Click(object sender, EventArgs e)
    {
        if (textBox1.Text.Length > 0)
        {
            Person p = new Person();
            p.Name = textBox1.Text;
            listPersons.Add(p);
        }
    }
}

class Person
{
    public string Name { get; set; }
}

当您按下按钮时,数据会添加到列表中,但不会显示在DataGridView. 我错过了什么?

我尝试设置AutoGenerateColumnsand VirtualModeto true,但这也没有解决问题。

4

6 回答 6

3

已经有一段时间了,自从处理尝试将 List<T>s 绑定到 DataGridViews 的 WinForms 代码以来,我已经换了工作。如果我没记错的话,无论你绑定什么都需要实现 IBindingList,而 List<T> 没有。我可能是错的。

无论如何,我使用的是BindingListView,它非常快速和简单。你只需这样做:

List<Customer> customers = GetCustomers();
BindingListView<Customer> view = new BindingListView<Customer>(customers);
dataGridView1.DataSource = view; 

你完成了。我已经有几年没有看过源代码了,但我相信它用一个实现 IBindingList 的类包装了 List<T>。

于 2012-12-24T19:17:59.200 回答
2

但是,如果我只使用它BindingList<T>而不是List<T>它确实有效。

示例代码:

    BindingList<Person> bl;
    public Form1()
    {
        InitializeComponent();
        bl = new BindingList<Person>();
        dataGridView1.DataSource = bl;
    }

    private void button1_Click(object sender, EventArgs e)
    {
        if (textBox1.Text.Length > 0)
        {
            Person p = new Person();
            p.Name = textBox1.Text;
            bl.Add(p);
            textBox1.Text = "";
            textBox1.Focus();
        }
    }    

但我仍然想弄清楚如何在DataGridView与 List 绑定后显示数据。

于 2012-12-24T19:42:39.587 回答
0

集中您的FillGrid功能并在您想要更新网格时调用它

public Form1()
{
    InitializeComponent();
     listPersons = new List<Person>();

    FillGrid();
}

private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text.Length > 0)
    {
        Person p = new Person();
        p.Name = textBox1.Text;
        listPersons.Add(p);

        FillGrid();
    }
}

private void FillGrid()
{
   dataGridView1.DataSource = listPersons;
}
于 2012-12-24T19:18:34.023 回答
0

我认为您不能直接将列表绑定到 datagridview。而是使用 BindingList。

public partial class Form1 : Form
{
    BindingList<Person> lstBinding;
    public Form1()
    {
        InitializeComponent();
        lstBinding = new BindingList<Person>();
        dataGridView1.DataSource = lstBinding;
    }

    private void button1_Click(object sender, EventArgs e)
    {
        if (textBox1.Text.Length > 0)
        {
            Person p = new Person();
            p.Name = textBox1.Text;
            lstBinding.Add(p);
            FillGrid();
        }
    }
    private void FillGrid()
    {
        dataGridView1.DataSource = lstBinding;
    }
}

class Person
{
    private string name;
    public string Name 
    { 
        get {return name;}
        set { name = value; } 
    }
}
于 2012-12-25T11:22:19.607 回答
0

使用数组绑定datagridview,即

 public partial class Form1 : Form
{

    Person[] listPersons = new Person[0];
    public Form1()
    {
        InitializeComponent();
        dataGridView1.DataSource = listPersons;
    }

    private void button1_Click(object sender, EventArgs e)
    {
        if (textBox1.Text.Length > 0)
        {
            Person p = new Person();
            p.Name = textBox1.Text;
            Array.Resize<Person>(ref listPersons, listPersons.Length+1);
            listPersons[listPersons.Length-1]=p;
            dataGridView1.DataSource = listPersons;
        }

    }


}
class Person
{
    public string Name { get; set; }
}
于 2012-12-25T13:01:30.733 回答
-1

dataGridView1.Refresh();添加到列表后尝试调用。

于 2012-12-24T19:14:26.260 回答