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列表的成员设置CustomerInfo为DatagridView控件的数据源。
谢谢
首先,您必须以某种方式公开您的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)
| 归档时间: |
|
| 查看次数: |
30527 次 |
| 最近记录: |