Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/283.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何在ASP.NET MVC视图中对数据进行分组?_C#_Asp.net Mvc_Linq_Linq To Sql_Reporting - Fatal编程技术网

C# 如何在ASP.NET MVC视图中对数据进行分组?

C# 如何在ASP.NET MVC视图中对数据进行分组?,c#,asp.net-mvc,linq,linq-to-sql,reporting,C#,Asp.net Mvc,Linq,Linq To Sql,Reporting,在诸如Crystal Reports之类的报告工具中,有一些方法可以获取非规范化数据并按数据中的特定列对其进行分组,从而为指定列中的每个唯一项创建行标题 如果我有这个: Category1 Data1 Category1 Data2 Category1 Data3 Category2 Data4 Category2 Data5 Category2 Data6 报告软件将对其进行如下分组: Category1 Data1 Data2

在诸如Crystal Reports之类的报告工具中,有一些方法可以获取非规范化数据并按数据中的特定列对其进行分组,从而为指定列中的每个唯一项创建行标题

如果我有这个:

Category1    Data1
Category1    Data2
Category1    Data3
Category2    Data4
Category2    Data5
Category2    Data6
报告软件将对其进行如下分组:

Category1
      Data1
      Data2
      Date3
Category2
      Data4
      Data5
      Data6

在ASP.NET MVC视图中,有没有一种方法可以做到这一点,可以使用简单的linq短语或linq扩展方法与foreach或嵌套foreach一起使用?

如果您的视图是强类型的,您可以将linq GroupBy扩展方法与嵌套foreach一起使用:

<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>

@foreach(Model.GroupBy(p=>p.PlanName)中的var计划)
{
@计划,钥匙
@foreach(计划中的var plan1)
{
@计划1.计划详情
@计划1.计划选项
}
}

但您将如何将其发布到控制器,实际上我得到的结果为空。这可以从一些解释中受益。
public class ViewModel
{
    public string Category { get; set; }
    public string Data { get; set; }
}
<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>