Просмотр с большим количеством компонентов.Несколько модельных объектов? - PullRequest
2 голосов
/ 09 апреля 2011

Я разрабатываю небольшое приложение MVC.

Проблема: у меня есть страница просмотра, на которой есть форма для добавления событий, форма для поиска событий и список событий.

Нет ничего сложного в том, чтобы разместить компоненты в отдельных представлениях, но они мне нужны на одной странице. Я хочу постоянную форму над списком событий.

Проблема в том, что я не знаю, что выбрать в качестве модельного объекта для вида. Если я выбираю Список событий, он прекрасно работает со списком, но не с формой. Если я выберу конкретный объект модели, соответствующий форме, у списка возникнет проблема.

Как лучше всего обрабатывать такие представления с помощью форм, списков, ...?

Это мой взгляд:

<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master"
Inherits="ViewPage<EventPlaza.Web.Models.EventsListViewModel>" %>
<%@ Import Namespace="EventPlaza.Storage.Model" %>
<%@ Import Namespace="EventPlaza.Web.HtmlHelpers" %>

 <asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
   Home Page
 </asp:Content>



<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

<div id="EventControlsContainer">
            <h3><a href="#">Add Event Link</a></h3>
                <div>                    
            <% Html.RenderPartial("AddEvent", new AddEventModel()); %>
            </div>
            <h3><a href="#">Search for Events</a></h3>
                <div>
    <form>
           Place:
        <input id="elementID" name="elementID" type="text" class="inputSearch" />
           Date:
        <input id="datepicker" name="elementID2" type="text" class="inputSearch" />
        <input id="addEvent" type="submit" value="Find Events" />
    </form>
 </div>
        </div>      

   <% foreach(var product in Model.Events) { %>
    <% Html.RenderPartial("EventSummary", product); %>
<% } %>


    <div class="pager">
    <%: Html.PageLinks(Model.PagingInfo,
        x => Url.Action("List", new {page=x})) %>
</div>
</asp:Content>

Это элемент управления AddEvent View:

<%@ Control Language="C#"    Inherits="System.Web.Mvc.ViewUserControl<EventPlaza.Storage.Model.AddEventModel>"%>

                 <% Html.EnableClientValidation(); %>
<% using (Html.BeginForm("AddEvent", "Event", FormMethod.Post)) { %>
                     Event Link:    
                     <%: Html.TextBoxFor(x => x.EventLink) %>                     
                        Event Name:                            
                     <%: Html.TextBoxFor(x => x.EventName) %><br />
                        Place:                            
                     <%: Html.TextBoxFor(x => x.Place) %>    
                        Starting Date:                            
                     <%: Html.TextBoxFor(x => x.StartingDate) %>    <br />
                        End Date: 
                     <%: Html.TextBoxFor(x => x.EndDate) %>    
                    <input id="Submit" type="submit" value="Add Event" />
            <% } %>

1 Ответ

4 голосов
/ 09 апреля 2011

Я настоятельно рекомендую вам не использовать объект Model из вашей доменной модели напрямую в качестве типа представления, вместо этого вы должны создать собственный EventViewModel и сохранить три разных объекта, соответствующих каждому частичному представлению, которое у вас есть.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...