Привязка модели к вложенным дочерним моделям и частичным представлениям в ASP.NET MVC
-
20-09-2019 - |
Вопрос
У меня есть следующие типы и классы:
namespace MVC.Models
public class Page
{
public EditableContent Content {get; set; }
}
public class EditableContent
{
public TemplateSection SidebarLeft {get; set; }
public TemplateSection SidebarRight {get; set; }
}
Я хочу отредактировать Page
пример в моем Edit.aspx
Вид.Потому что EditableContent
также прилагается к другим моделям, у меня есть PartialView
вызванный ContentEditor.ascx
который строго типизирован и принимает экземпляр EditableContent
и визуализирует это.
Часть рендеринга работает нормально, но когда я публикую - все внутри моего ContentEditor
не привязан - это означает , что Page.Content
является null
.
В PartialView я использую для этого строго типизированные HTML-помощники:
<%= Html.HiddenFor(m => m.TemplateId) %>
Но поскольку входные элементы в форме, которые визуализируются с помощью ContentEditor.ascx
не получает Content
префикс к его id
атрибут - значения не привязаны к Page
.
Я попытался использовать слабо типизированные помощники, чтобы преодолеть это:
<%= Html.Hidden("Content.TemplateId", Model.TemplateId) %>
И когда я имею дело с собственностью, которая является List<T>
от чего-то это становится очень некрасиво.Затем я должен отобразить индексы коллекции вручную.
Должен ли я поместить как Страницу, так и EditableContent в качестве параметров для действия контроллера?:
public ActionResult Edit(Page page, EditableContent content) { ... }
Что я упускаю из виду?
Решение
Я бы посоветовал вам использовать EditorFor
помощник
Модель:
public class EditableContent
{
public string SidebarLeft { get; set; }
public string SidebarRight { get; set; }
}
public class Page
{
public EditableContent Content { get; set; }
}
Просмотры/Главная страница/Index.aspx:
<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<ToDD.Models.Page>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
Home Page
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<% using (Html.BeginForm()) { %>
<%--
This is the important part: It will look for
Views/Shared/EditorTemplates/EditableContent.ascx
and render it. You could also specify a prefix
--%>
<%= Html.EditorFor(page => page.Content, "Content") %>
<input type="submit" value="create" />
<% } %>
</asp:Content>
Просмотры/ Общие /Редактируемые шаблоны/EditableContent.ascx:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<ToDD.Models.EditableContent>" %>
<%= Html.TextBoxFor(m => m.SidebarLeft) %>
<br/>
<%= Html.TextBoxFor(m => m.SidebarRight) %>
И, наконец, Контроллер / HomeController:
public class HomeController : Controller
{
public ActionResult Edit()
{
var page = new Page
{
Content = new EditableContent
{
SidebarLeft = "left",
SidebarRight = "right"
}
};
return View(page);
}
[HttpPost]
public ActionResult Edit(Page page)
{
return View(page);
}
}