Шаблон редактора .Net MVC не возвращает данные при обратной передаче - PullRequest
0 голосов
/ 10 июня 2018

У меня есть требование, где мне нужно отобразить список динамических флажков (данные, поступающие из базы данных).У меня есть модель представления для флажка.

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);

1 Ответ

0 голосов
/ 10 июня 2018

Ваш текущий код шаблона редактора будет генерировать HTML-разметку, как показано ниже для каждого элемента в коллекции Amenities

<label>
       <img src="SomeImageSourceValue" style="height: 30px; width: 30px;">
       <input type="checkbox"> AminityTitle
</label>

Флажок не имеет значения атрибута name!Для работы привязки модели значение атрибута элемента формы name должно совпадать с именем свойства вашего класса (, которое вы используете в качестве параметра метода действия HttpPost ).Поэтому в идеале нам нужно, чтобы он генерировался следующим образом

<input type="checkbox" name="Amenities[0].Checked" value="true">
<input type="checkbox" name="Amenities[1].Checked" value="true">
<input type="checkbox" name="Amenities[2].Checked" value="true">

Хорошая новость: если вы правильно используете вспомогательный тег ввода, он сгенерирует правильную разметку для вас.

@model HouseRentalManagement.Models.AdminViewModels.AmenitiesListViewModel

<div class="container mt-10" >

    <img src="@Model.ImageSrc" style="height: 30px; width: 30px;" />

    <input type="checkbox" asp-for="Checked" /> @Model.Title
    <input type="hidden" asp-for="AmenityId" />

</div>
...