如何在C#中将数据源设置为Datagridview控件

Kir*_*ran 1 c# data-binding binding datagridview

这看起来很简单,但是我不知道该怎么做。我不是C#中的数据绑定专家。

我有一个Class对象的列表(它是一个嵌套的Class),看起来像这样:

public class IntVector
{
    private string customerid;
    private string hash_id;
    private string client_name;
    private string mobile_no;
    private string address;

    //Table

    private List<CustomerInfo> customerinfo;
}
Run Code Online (Sandbox Code Playgroud)

我有一个清单 IntVector

private List<IntVector> UserData;
Run Code Online (Sandbox Code Playgroud)

现在,如何将UserData列表的成员设置CustomerInfoDatagridView控件的数据源。

谢谢

Ari*_*rie 5

首先,您必须以某种方式公开您的customerinfo列表(它现在是私有的,因此您不能从IntVector类外部获取它)。

如果是公开的:

BindingSource bs = new BindingSource(); 

int indexInUserDataList = 0;
bs.DataSource = UserData[indexInUserDataList].customerinfo;

datagridview.DataSource = bs;
Run Code Online (Sandbox Code Playgroud)

另外,如果您要以编程方式修改列表并希望将那些更改传播到控件,则可能要考虑使用BindingList而不是List(此处的区别是List <T>与BindingList <T>的优点/缺点)。

您的CustomerInfo类是什么样的?我假设您想将DataGridView的列绑定到CustomerInfo类的公共属性,例如:

class CustomerInfo 
{
   public int Id {get;set;}
   public string Name {get;set;}
   public string Address {get;set;}

   private string somePrivateData;
}
Run Code Online (Sandbox Code Playgroud)

现在,如果将DataGridView中的AutoGenerateColumns设置为true,则将在DataGridView中自动创建3列“ Id”,“ Name”和“ Address”。“ somePrivateData”将被忽略。

如果要自己定义列,则可以这样进行:

// make sure to do it before binding DataGridView control
datagridview.AutoGenerateColumns = false;

DataGridViewTextBoxColumn col1 = new DataGridViewTextBoxColumn();
col1.DataPropertyName = "Name";
col1.HeaderText = "Customer name";
col1.Name = "column_Name";
datagridview.Columns.Add(col1);

DataGridViewTextBoxColumn col2 = new DataGridViewTextBoxColumn();
col2.DataPropertyName = "Address";
col2.HeaderText = "Address";
col2.Name = "column_Address";
datagridview.Columns.Add(col2);
Run Code Online (Sandbox Code Playgroud)