ASP.NET MVC - EntityFramework e associazione a un elenco
-
05-07-2019 - |
Domanda
Attualmente sto usando EntityFramework per associare il mio progetto ASP.NET MVC a un database MySQL e una delle mie entità, Product, ha una proprietà Images contenente una raccolta di ProductImages. Ho creato un modulo per consentire all'utente di modificare un determinato Prodotto e questo modulo include campi per la modifica di tutte le immagini associate a quel Prodotto. Dopo aver letto Phil Haack's e < a href = "http://www.distribucon.com/blog/ASPNETMVCRC1BindingAList.aspx" rel = "nofollow noreferrer"> post di Dan Miser ho un'idea decente di ciò che deve accadere, ma io non riesco a farlo funzionare per qualche motivo ...
Ecco il mio modulo di prodotto:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<KryptonCMS.Models.Product>" %>
<%@ Import Namespace="KryptonCMS.Core" %>
<%@ Import Namespace="KryptonCMS.Models.ViewModels" %>
<% using (Html.BeginForm())
{%>
<ul class="gallery">
<%
var index = 0;
foreach (var image in Model.ImageList.OrderBy(p => p.Order))
{
%>
<li>
<% Html.RenderPartial("ProductImageForm", image, new ViewDataDictionary(ViewData) { { "index", index } }); %>
</li>
<%
index++;
}
%>
</ul>
<p>
<input type="submit" name="btnSave" value="Save" />
<input type="submit" name="btnCancel" value="Cancel" />
</p>
<% } %>
Ed ecco la definizione di ProductImageForm:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<KryptonCMS.Models.ProductImage>" %>
<%@ Import Namespace="KryptonCMS.Core" %>
<div>
<%
var fieldPrefix = string.Format("images[{0}]", ViewData["index"]); %>
<%=Html.Hidden(fieldPrefix + "ID", Model.ID) %>
<img src="<%=UtilityManager.GetProductImagePath(Model.Product.ID, Model.FileName, true) %>"
alt="" /><br />
<label for="Description">
Description:</label>
<%=Html.TextBox(fieldPrefix + "Description", Model.Description) %><br />
<label for="Order">
Order:</label>
<%=Html.TextBox(fieldPrefix + "Order", Model.Order)%><br />
</div>
E infine le mie azioni ProductsController:
public ActionResult Edit(int id)
{
var product = productsRepository.GetProduct(id);
if (product == null)
return View("NotFound", new MasterViewModel());
// else
return View(ContentViewModel.Create(product));
}
[AcceptVerbs(HttpVerbs.Post), ValidateInput(false)]
public ActionResult Edit(int id, FormCollection formCollection)
{
var product = productsRepository.GetProduct(id);
if (formCollection["btnSave"] != null)
{
if (TryUpdateModel(product) && TryUpdateModel(product.Images, "images"))
{
productsRepository.Save();
return RedirectToAction("Details", new { id = product.ID });
}
return View(ContentViewModel.Create(product));
}
// else
return RedirectToAction("Details", new { id = product.ID });
}
L'output HTML per un singolo ProductImageForm è simile al seguente:
<div>
<input id="images[0]ID" name="images[0]ID" type="hidden" value="1" />
<img src="/Content/ProductGallery/3/thumbs/car1.jpg"
alt="" /><br />
<label for="Description">
Description:</label>
<input id="images[0]Description" name="images[0]Description" type="text" value="FAST CAR" /><br />
<label for="Order">
Order:</label>
<input id="images[0]Order" name="images[0]Order" type="text" value="1" /><br />
</div>
Ho provato tutti i tipi di metodi per riorganizzare il mio modulo, incluso estrarre la raccolta di immagini dal modulo del prodotto e metterlo nel suo (cosa che non voglio davvero fare), ma nulla funziona. C'è qualcosa di palesemente sbagliato nel mio approccio qui?
Soluzione
Mancano punti nei nomi degli input:
<%= Html.Hidden(fieldPrefix + ".ID", Model.ID) %>
<%= Html.TextBox(fieldPrefix + ".Description", Model.Description) %>
<%= Html.TextBox(fieldPrefix + ".Order", Model.Order) %>
Controlla questo post del blog: http://www.hanselman.com/blog/ASPNETWireFormatFoModellCoModell aspx