明确我们将要的展现形式如图:
来看看原视图:
1 @if (Model.NotFilteredItems.Count > 0) 2 { 3 <div> 4 <table class="filter"> 5 @foreach (var item in Model.NotFilteredItems) 6 { 7 if (!renderedAttributeNames.Contains(item.SpecificationAttributeName)) 8 { 9 renderedAttributeNames.Add(item.SpecificationAttributeName); 10 <tr class="group"> 11 <td> 12 @item.SpecificationAttributeName 13 </td> 14 </tr> 15 } 16 <tr class="item"> 17 <td> 18 <a href="@item.FilterUrl">@item.SpecificationAttributeOptionName</a> 19 </td> 20 </tr> 21 } 22 </table> 23 </div> 24 }
输出结果为下图:
很显然达不到我们的理想要求? 因此考虑使用GroupBy()方法来通过制定键值来对序列进行分组排序,迭代IGrouping<TKey, TElement>
输出从而达到我的实现目标。如:

if (Model.NotFilteredItems.Count > 0) { IEnumerable<IGrouping<string, CatalogPagingFilteringModel.SpecificationFilterItem>> spcGroup1 = Model.NotFilteredItems.GroupBy(e => e.SpecificationAttributeName); foreach (IGrouping<string, CatalogPagingFilteringModel.SpecificationFilterItem> spcGroup in spcGroup1) { <dl> <dt>@spcGroup.Key :</dt> <dd> @foreach (CatalogPagingFilteringModel.SpecificationFilterItem item in spcGroup) { <div> <a href="@item.FilterUrl">@item.SpecificationAttributeOptionName</a> </div> } </dd> </dl> } }