Foreach Razor里面的Foreach
我正在尝试编写一个foreach循环,它将找到每个不同的类别类型,然后列出具有该类别分配的每个Title。
例如:
@model IEnumerable @{ ViewBag.Title = "Home"; } @foreach (var item in Model) { @Html.DisplayFor(modelItem => item.ProgramType.ProgramType)
foreach (var listing in Model) { - @Html.DisplayFor(modelItem => listing.ProgramTitle)
} }
调查回复模型:
public class SurveyProgramModel { [Key] public int ProgramId { get; set; } public int ProgramYear { get; set; } public int ProgramStatusId { get; set; } public string ProgramTitle { get; set; } public virtual SurveyProgramModel SurveyProgramModel { get; set; } public virtual PersonModel PersonModel { get; set; }
}
我遇到了两个问题。
1.)我需要它只显示一次每个类别,而不是列出每个项目实例的类别。
2.)它显示所有ProgramTitle,而不仅仅是该循环的ProgramTitle。
不确定我应该使用的语法是什么。
如果我理解正确,那应该是这样的
@foreach (var item in Model) { @Html.DisplayFor(modelItem => item.ProgramType.ProgramType)
foreach (var listing in item.SurveyResponseModels) { - @Html.DisplayFor(modelItem => listing.ProgramTitle)
} }
看起来您需要在控制器中按ProgramType对枚举进行分组。 这将使视图保持良好和干净。
IEnumerable models = Foo(); //however you got them... var grouped = models.GroupBy(s => s.ProgramType.ProgramType); return View(grouped);
然后,您的视图更简单。 (修复模型类型后)。
@for(int i = 0; i < Model.Count; i++) { @Html.DisplayFor(model => model[i].Key)
for(int j = 0; j < Model[i].Count; j++) { - @Html.DisplayFor(model => model[i][j].ProgramTitle)
}
}
替代方案:
或者,您列出了一个列表:
var models = Foo(); var grouped = models.GroupBy(s => s.ProgramType.ProgramType) .Select(x => x.Select(y => y)) .ToList(); return View(grouped);
然后你的观点略有改变:
@for(int i = 0; i < Model.Count; i++) { @Html.DisplayFor(model => model[i].First().ProgramType.ProgramType)
for(int j = 0; j < Model[i].Count; j++) { - @Html.DisplayFor(model => model[i][j].ProgramTitle)
}
}