Генерация списка RadioButton MVC3 в циклическом выражении
Мой коллега создал модель, и вот она.
модель
[Serializable]
public class ModifyCollegeListModel
{
public List<SchoolModel> CollegeList { get; set; }
public List<SchoolListModel> SchoolList { get; set; }
public string Notes { get; set; }
public int QuestionnaireId { get; set; }
}
[Serializable]
public class SchoolModel
{
public Guid SchoolId { get; set; }
public string SchoolName { get; set; }
public string StateName { get; set; }
public int DisplayIndex { get; set; }
public int DetailId { get; set; }
public int CategoryId { get; set; }
public int? ApplicationStatusId { get; set; }
}
Я намереваюсь создать цикл, который будет генерировать список радиокнопок для ApplicationStatusId, что-то вроде этого...
Код бритвы
@foreach (SchoolModel justright in Model.CollegeList.Where(m => m.CategoryId == 3).OrderBy(m => m.SchoolName).ToList<SchoolModel>())
{
<tr class="@HtmlHelpers.WriteIf(eventCounter % 2 == 0, "even", "odd")">
<td class="school"><b>@justright.SchoolName</b></td>
<td class="location"><b>@justright.StateName</b></td>
<td><label>@Html.RadioButtonFor(x => justright.SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.DidNotApply)</label></td>
<td><label>@Html.RadioButtonFor(x => justright.SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.Accepted)</label></td>
<td><label>@Html.RadioButtonFor(x => justright.SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.NotAccepted)</label></td>
</tr>
}
но что происходит, так это то, что ВСЕ созданные радиобутоны имеют одно и то же имя, поэтому они сгруппированы в одну гигантскую коллекцию радиокнопок. не через школьный идентификатор... чешет голову
Может ли кто-нибудь помочь мне здесь и указать правильное направление, как я смогу создавать переключатели, сгруппированные по ряду?
1 ответ
Я бы сделал две вещи.
Прежде всего, я бы удалил логику фильтрации из представления. Я имею в виду эту часть:
Model.CollegeList.Where(m => m.CategoryId == 3).OrderBy(m => m.SchoolName).ToList<SchoolModel>()
Такая логика принадлежит сервису. Также это сделает взгляд намного чище.
Во-вторых, я думаю, вам нужно использовать цикл for, чтобы MVC связывал все обратно так, как вы хотите:
for (int i = 0; i < Model.CollegeList.Count; i++) {
<tr class="@HtmlHelpers.WriteIf(eventCounter % 2 == 0, "even", "odd")">
<td class="school"><b>@CollegeList[i].SchoolName</b></td>
<td class="location"><b>@CollegeList[i].StateName</b></td>
<td><label>@Html.RadioButtonFor(x => x.CollegeList[i].SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.DidNotApply)</label></td>
<td><label>@Html.RadioButtonFor(x => x.CollegeList[i].SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.Accepted)</label></td>
<td><label>@Html.RadioButtonFor(x => x.CollegeList[i].SchoolId, (int)BrightHorizons.CC.BusinessLogic.CollegeListApplicationStatusEnum.NotAccepted)</label></td>
</tr>
}
После использования цикла for вы заметите, что имена и идентификаторы радиокнопок также содержат свой индекс в CollegeList. Например:
<input id="CollegeList_0__SchoolId" name="CollegeList[0].SchoolId" type="radio" value="2">