Если модель представляет собой список объектов, то @Html.LabelFor model => model[i].member)
создает пустой атрибут for
.
DisplayName работает правильно, привязка к модели также отлично работает. Единственное, что не работает, это атрибут for
.
Ниже приведены две версии кода MVC. Первые 3 фрагмента кода предназначены для комбинации модели, контроллера и представления, которая не работает (модель представляет собой список). Второй набор из 3 фрагментов кода работает. На этот раз список завернут в объект.
Что мне не хватает?
Модель:
public class ViewModel {
public bool ClickMe { get; set; }
}
Контроллер:
public ActionResult LabelForViewModel() {
List<ViewModel> model = new List<ViewModel>() {
new ViewModel() { ClickMe = true}
};
return View(model);
}
Вид:
@model List<ModelBinding.Models.ViewModel>
// form code removed for brevity
@for (var i = 0; i < Model.Count; i++) {
<div class="form-group">
@Html.LabelFor(model => model[i].ClickMe)
<div class="col-md-10">
@Html.EditorFor(model => model[i].ClickMe, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model[i].ClickMe, "", new { @class = "text-danger" })
</div>
</div>
}
Разметка:
<div class="form-group">
<label for="">ClickMe</label>
<div class="col-md-10">
<input name="[0].ClickMe" class="form-control check-box" type="checkbox" checked="checked" value="true" data-val-required="The ClickMe field is required." data-val="true"><input name="[0].ClickMe" type="hidden" value="false">
<span class="field-validation-valid text-danger" data-valmsg-replace="true" data-valmsg-for="[0].ClickMe"></span>
</div>
</div>
Обратите внимание, что поле for пусто и вход не имеет поля id (это поле используется в поле "для" ).
Я создал модель обертки, которая содержит список объектов, модифицировала контроллер и представление, а затем она работает нормально. В этом случае поле "for" заполняется правильно, и все работает так, как ожидалось.
public class ListWrapper {
public List<ViewModel> ViewModels { get; set; }
}
Вид:
@for (var i = 0; i < Model.ViewModels.Count; i++) {
<div class="form-group">
@Html.LabelFor(model => model.ViewModels[i].ClickMe)
<div class="col-md-10">
@Html.EditorFor(model => model.ViewModels[i].ClickMe, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.ViewModels[i].ClickMe, "", new { @class = "text-danger" })
</div>
</div>
}
Разметка:
<div class="form-group">
<label for="ViewModels_0__ClickMe">ClickMe</label>
<div class="col-md-10">
<input name="ViewModels[0].ClickMe" class="form-control check-box" id="ViewModels_0__ClickMe" type="checkbox" checked="checked" value="true" data-val-required="The ClickMe field is required." data-val="true"><input name="ViewModels[0].ClickMe" type="hidden" value="false">
<span class="field-validation-valid text-danger" data-valmsg-replace="true" data-valmsg-for="ViewModels[0].ClickMe"></span>
</div>
</div>
Итак, кажется, что атрибут for
пуст, только если модель представляет собой список объектов.
Это известная проблема? Или, может быть, я что-то упустил?