Hello, I was trying to bind to a Model that contains objects as it's property.
Let's say I have a model that looks like
public class Person {
public Name Name {get;set;}
public int Age {get;set;
}
public class Name {
public string FirstName {get;set;}
public string LastName {get;set;}
Now somewhere in my data access code I have method that looks like.
public IList<Person> GetAll(int personId) {
return new List<Person> {
new Person {
new Name { FirstName="Vice", LastName="Ganda" },
Age = 27 } };
Now, the object datasource is using tthe method above to bind to my WebDataGrid, the markup looks like (Please ignore the TypeName)
<asp:ObjectDataSource ID="GetPersonsODS" runat="server"
SelectMethod="GetAll"
TypeName="System.Data.Repositories.PersonRepository">
<SelectParameters>
<asp:QueryStringParameter DefaultValue="0" Name="personId"
QueryStringField="personId" Type="Int32" />
</SelectParameters>
</asp:ObjectDataSource>
And in my WebDataGrid I would like to access the Name's Properties FirstName and LastName
I want something like this in bound datafield to access the FirstName property of the Name object.
<ig:BoundDataField DataType="MySystem.Data.Entities.Person" DataFieldName="Name.FirstName" Key="FirstName">
<Header Text="FirstName" />
</ig:BoundDataField>
But this gives me an error like this
Data source field with name 'Person.FirstName cannot be found. Please set the DataFieldName property for the field with 'FirstName' key to correspond to a data field in the data source.
I think I'm missing something, please help.
Thank you and best regards,
Hi,
Binding to sub properties of objects in the model is a feature request. You can display the data with a template as said, but sorting, filtering, etc is not available for those columns. Another option would be to set the value of these properties into an unbound cell in the grid. Then that column could be sorted, filtered. But any updates to the values would need to be manually handled by you.
regards,
David Young
I'm attaching one sample as like , here the sorting not works in the Firstname and Last Name
Hello guys,
To achieve this you should use TemplateDataField, for example:
<ig:TemplateDataField Key="FitstName"> <ItemTemplate> <asp:Label ID="Label1" runat="server"><%# DataBinder.Eval(((Infragistics.Web.UI.TemplateContainer)Container).DataItem, "Name.FirstName") %> </asp:Label> </ItemTemplate></ig:TemplateDataField>
I am attaching a small sample for your reference.
Any solution available for this post, like subclass field as key field .
Sherwin,
Were you able to find a solution to this problem?