Привязка модели с вложенными дочерними моделями и PartialViews в ASP.NET MVC

У меня есть следующие типы и классы:

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 также присоединен к другим моделям, у меня есть a 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) %>

И когда я имею дело со свойством, которое является a List<T> из чего-то это становится очень ужасным. Я затем должен представить индексы набора вручную.

Я должен поместить и Page и EditableContent как параметры к действию контроллера?:

public ActionResult Edit(Page page, EditableContent content) { ... }

Что я пропускаю?

9
задан Uwe Keim 23 July 2013 в 14:32
поделиться

1 ответ

Я предлагаю вам использовать EditorFor помощник

Модель:

public class EditableContent
{
    public string SidebarLeft { get; set; }
    public string SidebarRight { get; set; }
}

public class Page
{
    public EditableContent Content { get; set; }
}

Views / Home / 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>

Views / Shared / EditorTemplates / EditableContent.ascx:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<ToDD.Models.EditableContent>" %>

<%= Html.TextBoxFor(m => m.SidebarLeft) %>
<br/>
<%= Html.TextBoxFor(m => m.SidebarRight) %>

И, наконец, Controller / 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);
    }
}
18
ответ дан 4 December 2019 в 11:41
поделиться
Другие вопросы по тегам:

Похожие вопросы: