У меня есть страница Редактирование элемента с несколькими частичными визуализированными формами для удаления изображений.Страница редактирования элемента:
@model EditModel
<form method="post" enctype="multipart/form-data">
<input asp-for="ItemModel.Id" type="hidden" />
<input asp-for="ItemModel.AllOtherFields" type="hidden" />
</form>
@if (Model.ItemModel.ImageViewModels != null && Model.ItemModel.ImageViewModels.Any())
{
foreach(var imageViewModel in Model.ItemModel.ImageViewModels)
{
Html.RenderPartial("ItemImage/_itemImageEdit", imageViewModel);
}
}
ItemImage / _itemImageEdit
@model ViewModels.ItemImageViewModel
<form asp-controller="Images" asp-action="Delete" method="post">
<input type="hidden" asp-for="@Model.Id" />
<img src="@Url.Action("Get", "Images", new { id = Model.Id })" />
<input type="submit" value="Delete" />
</form>
и вот мой странный финальный HTML
<form method="post" action="/Images/Delete/5" novalidate="novalidate">
<input type="hidden" data-val="true" data-val-required="The Id field is required." id="Id" name="Id" value="5">
<img src="/Images/Get/10">
<input type="submit" value="Delete">
</form>
Где 5 - идентификатор элемента и 10 - изображениеЯ бы.Так что это ожидаемо и правильно
<img src="/Images/Get/10">
, а это не так.Идентификатор элемента используется вместо идентификатора (ItemImageViewModel.id)
action="/Images/Delete/5"
Понятия не имею, почему @Model.Id
генерирует разные идентификаторы для одного и того же подпредставления.
Edit1:
public class ItemImageViewModel
{
[BindProperty]
public int Id { get; set; }
public string Title { get; set; }
public int ItemId { get; set; }
}
public class ItemViewModel
{
public ItemViewModel()
{
}
public ItemViewModel(ItemViewModel vm)
{
Id = vm.Id;
Title = vm.Title;
ImageViewModels = vm.ImageViewModels;
}
public int Id { get; set; }
public string Title { get; set; }
public IEnumerable<ItemImageViewModel> ImageViewModels { get; set; }
}
Я удалил несвязанные поля.Отладчик показывает нормально