Rob*_*vey 20 c# linq asp.net-mvc reporting linq-to-sql
在Crystal Reports等报表工具中,有一些方法可以获取非规范化数据并将其按数据中的特定列分组,从而为指定列中的每个唯一项创建行标题.
如果我有这个:
Category1 Data1
Category1 Data2
Category1 Data3
Category2 Data4
Category2 Data5
Category2 Data6
Run Code Online (Sandbox Code Playgroud)
报告软件会将其分组如下:
Category1
Data1
Data2
Date3
Category2
Data4
Data5
Data6
Run Code Online (Sandbox Code Playgroud)
有没有办法在ASP.NET MVC视图中执行此操作,可能使用简单的linq短语或linq扩展方法与foreach或嵌套的foreach?
Jas*_*son 49
如果您的视图是强类型的,则可以将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>
Run Code Online (Sandbox Code Playgroud)
这将提供与原始问题中的格式化列表非常相似的输出.它假设您的模型看起来像:
public class ViewModel
{
public string Category { get; set; }
public string Data { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
29609 次 |
| 最近记录: |