我可以在LinQ中定义默认排序顺序

时间:2009-03-26 19:02:51

标签: asp.net linq 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>

也许这种方法看似简单,但我希望内部产品按字段排序。我没有办法以声明的方式做到这一点,因为LinQ动态创建了这个查询,如果我没有弄错,并且不进行排序。

有什么想法吗?

更新

将示例更新为以下内容:

<%# ((Category)Container.DataItem).Products.OrderBy(p => p.Description) %>

希望它可以帮助别人!

1 个答案:

答案 0 :(得分:5)

我的假设是产品是IEnumerable<Product>(或IQueryable)。如果是这种情况,为什么不直接将OrderBy方法添加到评估中,如下所示:

<%# Eval("Products.OrderBy(p => p.FieldToSortOn)") %>