asp.net привязка gridview к более глубокому свойству определенного типа - PullRequest
2 голосов
/ 14 октября 2011

мой сайт имеет сетку я связываю его с набором данных, полученным из powershell

в этом наборе данных много разных типов данных.

все работает нормально, но для одного поля я хотел бы привязать более глубокое свойство к ограниченному полю!

Я связываю это так:

с #

GridViewAgentGroups.DataSource = dt;
GridViewAgentGroups.DataBind();

Разметка

        <asp:BoundField DataField="Name" HeaderText="Name" ReadOnly="True" />
        <asp:BoundField HeaderText="Service" ReadOnly="True"
                        DataField="Identity" />
        <asp:BoundField DataField="Description" HeaderText="Description" 
                        ReadOnly="True" />

граничное поле службы привязывается к данным типа: "Microsoft.Rtc.Rgs.Management.RgsIdentity"

содержит свойство instanceID и serviceID, а serviceID содержит свойство fullName!

когда я связываю его напрямую, как "DataField="Identity", он показывает очень длинную строку с включенным полным именем!

есть ли способ привязать только полное имя? как "DataField="Identity.ServiceID.FullName"? в XML? (это не работает :-)

1 Ответ

3 голосов
/ 14 октября 2011

Да, это возможно с TemplateFields, но это также зависит от дизайна dataSource. Посмотрите на этот образец:

Markup:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
    <Columns>
        <asp:TemplateField>
            <ItemTemplate>
                <%#Eval("Name") %>
                <%#Eval("GroupName.Name") %>
                <%#Eval("GroupName.RegionName.Name") %>
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
</asp:GridView>

Код позади:

public class Region
{
    public string Name { get; set; }
}
public class Group
{
    public string Name { get; set; }
    private Region _region=new Region();
    public Region RegionName { get { return _region; } set { _region = value; } }
}
public class Product
{
    public string Name { get; set; }
    private Group _groupName = new Group();
    public Group  GroupName { get { return _groupName; } set { _groupName = value; } }
}
public class Products : List<Product>
{
}
protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        Region reg1 = new Region() { Name = "North" };
        Region reg2 = new Region() { Name = "East" };
        Group group1 = new Group() { Name="Group1", RegionName=reg1  };
        Group group2 = new Group() { Name = "Group2", RegionName=reg1 };
        Group group3 = new Group() { Name = "Group3", RegionName = reg2 };
        Products prod = new Products()
        {
                new Product(){ Name="Product1", GroupName=group1},
                new Product(){ Name="Product1", GroupName=group2},
                new Product(){ Name="Product2", GroupName=group3},
                new Product(){ Name="Product3", GroupName=group1},
                new Product(){ Name="Product2", GroupName=group2},
        };

        GridView1.DataSource = prod;
        GridView1.DataBind();
    }
}
...