2009-01-13 74 views
2

有没有办法将对象的子属性绑定到datagridview?这里是我的代码:将子属性绑定到DataGridView

public class Person 
{ 
    private string id; 
    private string name; 
    private Address homeAddr; 
    public string ID 
    { 
     get { return id; } 
     set { id = value; } 
    } 
    public string Name 
    { 
     get { return name; } 
     set { name = value; } 
    } 
    public Address HomeAddr 
    { 
     get { return homeAddr; } 
     set { homeAddr = value; } 
    } 
} 

public class Address 
{ 
    private string cityname; 
    private string postcode; 
    public string CityName 
    { 
     get { return cityname; } 
     set { cityname = value; } 
    } 
    public string PostCode 
    { 
     get { return postcode; } 
     set { postcode = value; } 
    } 
} 

而且,当Person类型的对象绑定到datagridview时,我想显示ID,Name,CityName。请注意,CityName是HomeAddr的一个属性。

+0

你想CITYNAME和邮编在一列或两个单独的列? – BFree 2009-01-13 02:58:21

+0

当然是两列。 – Graviton 2009-01-13 03:15:43

回答

0

如果你有DataGridView AutoGenerateColumns = true,真的没有简单的方法来做到这一点。您最好的选择是提前设置DataGridView,然后手动填充DataGridView。

或者,您可以实施ITypedList,但如果您问我,那会有点痛苦。

0

BLToolkit有BLToolkit.ComponentModel.ObjectBinder

这些特点是:

Support for field binding along with property binding. 

Support for inner class field and property binding such as Order.Address.Line1. 

Support for the ObjectView feature which is available by assigning an object view type to the ObjectBinder.ObjectViewType property. An object view is an object that implements the IObjectView interface. This interface includes only one property - object Object { get; set; }. An object view can implement additional properties based on the assosiated object. The ObjectBinder will combine all of these properties with main object properties and create a single PropertyDescriptor collection. This feature can be used to separate UI presentation logic from business model objects and to keep them clean. ObjectView should be a stateless, lightweight object as its single instance can be assigned to many assosiated objects. 

The ObjectBinder is optimized for high performance applications such real-time multithreaded message processing and distribution banking systems. So it does not use reflection to access objects. The standard way (which is used by the BindingSource) is to call the TypeDescriptor.GetProperties method to get a PropertyDescriptor collection. This method creates property descriptors that access object properties by reflection. The ObjectBinder has its own mechanism to avoid unnessasy reflection and boxing/unboxing operations.