-1
我试图将Linq的结果绑定到XML查询到DataList控件,并且无法返回所有子值。这里是我的XML ...Linq to XML选择所有父项和子项目
<categories>
<category>
<parent-id>1234</parent-id>
<parent-name>Parent 1</parent-name>
<children>
<child-cat>
<child-id>5678</child-id>
<child-name>Child 1</child-name>
</child-cat>
<child-cat>
<child-id>2824</child-id>
<child-name>Child 2</child-name>
</child-cat>
<child-cat>
<child-id>2831</child-id>
<child-name>Child 3</child-name>
</child-cat>
</children>
</category>
<category>
<parent-id>6398</parent-id>
<parent-name>Parent 2</parent-name>
<children>
<child-cat>
<child-id>5564</child-id>
<child-name>Child 1</child-name>
</child-cat>
<child-cat>
<child-id>2824</child-id>
<child-name>Child 2</child-name>
</child-cat>
<child-cat>
<child-id>2831</child-id>
<child-name>Child 3</child-name>
</child-cat>
</children>
</category>
这里是我的Linq查询...
var categories = XDocument.Load(Server.MapPath("/app_data/ShoppingCategories.xml"));
var allCats = from category in categories.Root.Descendants("category")
select new
{
parentId = category.Descendants("parent-id").First().Value,
parentName = category.Descendants("parent-name").First().Value,
childId = category.Descendants("child-cat").First().Value,
childName = category.Descendants("child-name").First().Value
};
dtlstCategories.DataSource = allCats;
dtlstCategories.DataBind();
我看起来就像这样(我只显示父名和儿童名称字段,该ID字段被绑定到隐藏字段)...
父1 父2
儿童1 孩子2
因为我使用.First()的子元素,我意识到这就是为什么只有第一个显示,但我似乎无法弄清楚如何让他们都显示。这是我后...
父1 父2
儿童1 儿童1
儿童2 儿童2
儿童3 孩子3
看起来我很接近得到我想要的东西,但我无法将它们全部结合在一起。任何帮助表示赞赏!
编辑
这里是我的DataList ...
<asp:DataList ID="dtlstCategories" runat="server" OnItemDataBound="dtlstCategories_ItemDataBound" Visible="True" RepeatColumns="5" RepeatDirection="Vertical" RepeatLayout="Table" ItemStyle-Wrap="True" BorderWidth="0" ItemStyle-HorizontalAlign="Left" ItemStyle-VerticalAlign="Top" ItemStyle-Width="170">
<ItemTemplate>
<div style="padding-left:10px; padding-right:10px;">
<asp:HiddenField ID="hdnTopCategoryId" runat="server" Value='<%#DataBinder.Eval(Container.DataItem, "parentId") %>' />
<asp:LinkButton ID="lnkTopCategory" runat="server" CssClass="support" Text='<%#DataBinder.Eval(Container.DataItem, "parentName") %>'></asp:LinkButton>
<asp:Image ID="imgCatDivider" runat="server" />
<asp:HiddenField ID="hdnChildCatId" runat="server" Value='<%#DataBinder.Eval(Container.DataItem, "childId") %>' />
<asp:LinkButton ID="lnkChildName" runat="server" CssClass="support" Text='<%#DataBinder.Eval(Container.DataItem, "childName") %>'></asp:LinkButton>
</div>
</ItemTemplate>
</asp:DataList>
这让我更接近,但现在我的输出看起来像这样...
– Padraig75
@ Padraig75像什么? – Eser
对不起......对于SO来说很新,并且在评论中挣扎着。基本上,我得到了父母1,孩子1,父母1,孩子2,父母1,孩子3等的垂直列表。而不是父母1,孩子1,孩子2,孩子3 – Padraig75