我有一个列表,我作为模型的一部分返回。我希望列表中的每个项目都显示在自己的行上。我有两种方法,都没有完成这项工作。
一种方法是使用foreach(),这将允许我在每个项目中使用休息或其他任何东西。但要做到这一点,我必须使模型IEnumerable(或至少我认为这是我必须做的),我不想这样做。
但是,如果我将它设为常规模型,则foreach()不起作用。任何人都可以指导我找到解决方案吗?
这就是我所说的“常规模式”(我太过于了解正确的术语)
@model AcademicAdvising.Models.AppointmentModel
以下是模型本身的列表
public List<string> ReferralTypeNames { get; set; }
以下是视图中现在的线条:
<p>@Html.DisplayFor(model => model.ReferralTypeNames)</p>
这样可行,但项目之间没有换行符。
UPDATE
这是我想要的样本:
学术部
学术提升 - 教程
招生
另一位学术顾问
以下是我得到的样本: 学术部门学术增强 - 教程招生另一位学术顾问
以下是表格其余部分的代码:
<table class="table-appt">
<tr>
<th>Student ID</th>
<td>@ViewBag.CurrentStudentId</td>
</tr>
<tr>
<th>Username</th>
<td>@ViewBag.CurrentStudentUsername</td>
</tr>
<tr>
<th>Name</th>
<td>@ViewBag.LName</td>
</tr>
<tr>
<th>Assigned Advisor</th>
<td>@Html.DisplayFor(model => model.AdvisorName)</td>
</tr>
<tr>
<th>Declared Major</th>
<td>@Html.DisplayFor(model => model.Major)</td>
</tr>
</table>
<fieldset>
<legend></legend>
<div class="field">
<h4>View a Different Advising Session</h4>
<div>
@Html.DisplayFor(model => model.AppointmentDates)
</div>
</div>
<div class="field">
<h3>Advisor</h3>
(person conducting appointment)<br />
<div>(name) @Html.DisplayFor(model => model.AdvisorId)</div>
</div>
<div class="field">
<h3>Contact/Appointment Type</h3>
<div>@Html.DisplayFor(model => model.ContactTypeName)</div>
</div>
<div class="field">
<h3>Appointment Notes</h3>
<div class="display-field">
@Html.DisplayFor(model => model.Notes)
</div>
</div>
<div class="field">
<h3>Advising Topics</h3>
<div>@Html.DisplayFor(model => model.AdvisingTopicNames)</div>
</div>
<div class="field">
<h3>Referral Topics</h3>
@Html.DisplayFor(model => model.ReferralTypeNames)<br />
</div>
</fieldset>
答案 0 :(得分:1)
试
@foreach (string s in Model.ReferralTypeNames)
{
@Html.DisplayFor(m => s)<br />
}