将对象绑定到DataGrid的列表

时间:2015-03-03 09:46:19

标签: c# datagrid compact-framework

我正在尝试将对象列表绑定到紧凑框架上的DataGrid。这就是我所拥有的:

public class Order
{
    //Other stuff
    public Customer Customer
    {
        get { return _customer; }
    }
}

public class Customer
{
    //Other stuff
    public string Address
    {
        get { return _address; }
    }
}

现在我想将DataGrid绑定到Order列表并仅显示某些属性(客户的地址就是其中之一):

List<Order> orders = MethodThatGetsOrders();
datagrid.DataSource = orders;
datagrid.TableStyles.Clear();
DataGridTableStyle ts = new DataGridTableStyle();
ts.MappingName = orders.GetType().Name; //This works OK
DataGridTextBoxColumn tb = new DataGridTextBoxColumn();
tb.MappingName = orders.GetType().GetProperty("Customer").GetType().GetProperty("Address").Name; //Throws NullRef
ts.GridColumnStyles.Add(tb);
datagrid.TableStyles.Add(ts);

如何在DataGridTextBoxColumn上显示客户的地址?
感谢

1 个答案:

答案 0 :(得分:2)

我会形成一个viewmodel(或者更好的适配器),然后再搞乱绑定并获得一个可以轻松绑定到的平面模型:

public class OrderViewModel
{
    private Order _order;

    public string Address 
    {
        get { return _order.Customer.Address; }
    }

    // similar with other properties

    public OrderViewModel(Order order)
    {
        _order = order;
    }
}

生成ViewModelList do:

List<OrderViewModel> viewModels = yourList.Select(m=> new OrderViewModel(m)).ToList();

简单地绑定:

YourGridView.Datasource = new BindingSource(viewModels, null);