linq 如何在ASP.NETMVC视图中对数据进行分组?

zzoitvuj  于 2023-10-13  发布在  .NET
关注(0)|答案(3)|浏览(123)

在像Crystal Reports这样的报表工具中,有一些方法可以获取非规范化的数据,并按数据中的特定列对其进行分组,为指定列中的每个唯一项创建行标题。
如果我有这个:

Category1    Data1
Category1    Data2
Category1    Data3
Category2    Data4
Category2    Data5
Category2    Data6

报告软件将其分组如下:

Category1
      Data1
      Data2
      Date3
Category2
      Data4
      Data5
      Data6

有没有一种方法可以在ASP.NETMVC视图中做到这一点,也许使用一个简单的linq短语或带有foreach或嵌套foreach的linq扩展方法?

4urapxun

4urapxun1#

如果你的视图是强类型的,你可以使用带有嵌套foreach的LINQ GroupBy扩展方法:

<ul>
<% foreach (var group in Model.GroupBy(item => item.Category)) { %>

   <li><%= Html.Encode(group.Key) %>
     <ul>

     <% foreach (var item in group) { %>
       <li><%= Html.Encode(item.Data) %></li>  
     <% } %>

     </ul>
   </li>

<% } %>
</ul>

这将提供与原始问题中的格式化列表非常相似的输出。它假设你的模型看起来像这样:

public class ViewModel
{
    public string Category { get; set; }
    public string Data { get; set; }
}
qni6mghb

qni6mghb2#

<table class="table table-striped table-bordered">
    @foreach (var plan in Model.GroupBy(p => p.PlanName))
    {
        <thead>
            <tr>
                <th></th>
                <th>
                    @plan.Key
                </th>
            </tr>
        </thead>
        <tbody>
            @foreach (var plan1 in plan)
            {
                <tr>
                    <td>@plan1.PlanDetails</td>
                    <td>@plan1.PlanOption</td>
                </tr>
            }
        </tbody>
        <tfoot>

        </tfoot>
    }

</table>
vxf3dgd4

vxf3dgd43#

将LINQ GroupBy与嵌套foreach一起使用
视图模型示例:

public class ViewModelData
{
    public string Category { get; set; }
    public string Data { get; set; }
}

视图

@model IEnumerable<ViewModels.ViewModelData>

<ul>
    @foreach (var group in Model.GroupBy(item => item.Category))
    {
        <li>@group.Key
            <ul>
                @foreach (var item in group)
                {
                    <li>@item.Data</li>
                }
            </ul>
        </li>
    }
</ul>

相关问题