У меня есть требование, где мне нужно отобразить список динамических флажков (данные, поступающие из базы данных).У меня есть модель представления для флажка.
public class AmenitiesListViewModel
{
public int AmenityId { get; set; }
public string Title { get; set; }
public bool Checked { get; set; }
public string ImageSrc { get; set; }
}
Другая модель представления, у которой есть объект ICollection для этой модели представления.
public class HouseAmenityViewModel
{
public HouseAmenityViewModel()
{
Amenities = new HashSet<AmenitiesListViewModel>();
}
[HiddenInput]
public Guid HouseId { get; set; }
public ICollection<AmenitiesListViewModel> Amenities { get; set; }
}
Затем я создал службу для подготовки списка флажков из базы данных.
var amenities = await _amenityRepository.ListAmenitiesAsync();
if (amenities != null)
{
model.HouseId = houseId;
foreach (var amenity in amenities)
{
model.Amenities.Add(new AmenitiesListViewModel
{
AmenityId = amenity.AmenityId,
Title = amenity.Description,
Checked = false,
ImageSrc = string.Format(_imageOptions.AmenityImagePath, amenity.ImageFileName)
});
}
}
На мой взгляд, я использую @Html.EditorFor
для визуализации списка флажков.
<form asp-action="UpdateHouseAmenity" asp-controller="Admin" method="post" id="update-amenity-form" class="amenity-form">
<input asp-for="HouseId" />
<div class="row"><div class="col-md-12">@Html.EditorFor(m => m.Amenities)</div></div>
<div class="row">
<div class="col-md-12 mt-10">
<button type="submit" class="btn btn-primary" id="update-amenity-button">Submit</button>
<button type="button" class="btn btn-danger">Reset</button>
</div>
</div>
</form>
и шаблон редактора выглядит следующим образом:
@model HouseRentalManagement.Models.AdminViewModels.AmenitiesListViewModel
<div class="container mt-10" style="width: 30%;
display: inline-block;
float: left;">
<label>
<img src="@Model.ImageSrc" style="height: 30px; width: 30px;" />
<input type="checkbox" @string.Format("{0}", Model.Checked ? "checked" : "") /> @Model.Title
</label>
</div>
Я получилсписок флажков отображается правильно на мой взгляд.Моя форма отправляется на указанное действие.
Проблема в том, что при отправке я ничего не получаю из коллекции @Html.EditorFor(m => m.Amenities)
.
контроллер:
public async Task<IActionResult> UpdateHouseAmenity(HouseAmenityViewModel model)
{
var result = await _houseService.UpdateHouseAmenitiesAsync(model);
}
Здесь следует обратить внимание на то, что это представление отображается с использованием Ajax после загрузки страницы.Ajax:
var loadAmenity = function () {
$.ajax({
url: "/Admin/GetHouseAmenities"
}).done(function (data) {
$('#amenity-info').html(data);
}).fail(function (a, textError) {
console.error(textError);
});
};
Контроллер:
var model = await _houseService.GetHouseAmenityViewModelAsync(new Guid());
return PartialView("~/Views/Admin/_HouseAmenityPartial.cshtml", model);