Arm*_*est 0 linq asp.net sorting listview nested
如果我有一个嵌套的ListView,并且我在LinQ中调用一个相关的表,我如何对它进行排序,而不依赖于父项的ItemDataBound事件?
伪代码(更新解决方案):
<asp:ListView ID="lv" runat="server" OnItemDataBound="lv_ItemDataBound" >
<LayoutTemplate>
<!-- Product Category Stuff -->
<asp:PlaceHolder Id="itemPlaceholder" runat="server"></asp:PlaceHolder>
</LayoutTemplate>
<ItemTemplate>
<asp:ListView ID="lvInner" runat="server" DataSource='<%# <%# ((Category)Container.DataItem).Products.OrderBy(p => p.Description) %> %>'>
<LayoutTemplate>
<ul>
<asp:PlaceHolder ID="itemPlaceholder" runat="server"></asp:PlaceHolder>
</ul>
</LayoutTemplate>
<ItemTemplate>
<li>Item Stuff</li>
</ItemTemplate>
</asp:ListView>
</ItemTemplate>
</asp:ListView>
Run Code Online (Sandbox Code Playgroud)
也许这种方法看似简单,但我希望内部产品按字段排序.我无法看到以声明方式执行此操作的方法,因为LinQ动态创建此查询,如果我没有弄错,并且不进行排序.
有什么想法吗?
UPDATE
将示例更新为以下内容:
<%# ((Category)Container.DataItem).Products.OrderBy(p => p.Description) %>
Run Code Online (Sandbox Code Playgroud)
希望它可以帮助别人!
我的假设是产品是IEnumerable<Product>(或IQueryable).如果是这种情况,为什么不将OrderBy方法添加到评估中,如下所示:
<%# Eval("Products.OrderBy(p => p.FieldToSortOn)") %>
Run Code Online (Sandbox Code Playgroud)