简体   繁体   English

MVC 3 ModelView在视图和控制器之间传递参数

[英]MVC 3 ModelView passing parameters between view & controller

I've been playing with MVC 3 in a test project and have the following issue. 我一直在测试项目中使用MVC 3,并且遇到以下问题。

I have Group & Subscriber entities and those are coupled through a SubscriberGroup table. 我有组和订阅者实体,它们通过一个SubscriberGroup表耦合。

Using the DetailView of Group I open a view of SubscriberGroup containing all subscribers. 使用Group的DetailView,我打开一个包含所有订户的SubscriberGroup视图。 This list has the option to filter. 该列表具有过滤选项。

So far it all works, however when I call the AddToGroup method on the controller it fails. 到目前为止,所有方法都有效,但是当我在控制器上调用AddToGroup方法时,它会失败。 Specifically it goes into the method but doesn't pass the subscriberCheckedModels list. 具体来说,它进入方法,但不通过subscriberCheckedModels列表。 Am I doing something wrong? 难道我做错了什么?

View: SubscriberGroup Index.aspx 视图:SubscriberGroup Index.aspx

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.master" Inherits="System.Web.Mvc.ViewPage<Mail.Models.SubscriberCheckedListViewModel>" %>
…
<h2 class="common-box-title">
        Add Subscribers to Group</h2>
    <p>
        <% using (Html.BeginForm("Index", "SubscriberGroup"))
           { %>
            <input name="filter" id="filter" type="text" />
            <input type="submit" value="Search" />

        <%} %>
    </p>
            <% using (Html.BeginForm("AddToGroup", "SubscriberGroup", Model,FormMethod.Get, null))
           { %>
           <fieldset>
    <div style="display: inline-block; width: 70%; vertical-align: top;">
        <% if (Model.subscribers.Count() != 0)
           { %>
        <table class="hor-minimalist-b">
            <tr>
                <th>
                    Add To Group
                </th>
                <th>
                    Full Name
                </th>
                <th>
                    Email
                </th>
                <th>
                    Customer
                </th>
            </tr>
            <% foreach (var item in Model.subscribers)
               { %>
            <tr>
                <td>
                    <%= Html.CheckBoxFor(modelItem => item.AddToGroup)%>
                </td>
                <td>
                    <%= Html.DisplayFor(modelItem =>  item.subscriber.LastName)%>
                    <%= Html.ActionLink(item.subscriber.FirstName + " " + item.subscriber.LastName, "Details", new { id = item.subscriber.SubscriberID })%>
                </td>
                <td>
                    <%: Html.DisplayFor(modelItem => item.subscriber.Email)%>
                </td>
                <td>
                    <%: Html.DisplayFor(modelItem => item.subscriber.Customer.Company)%>
                    <%= Html.HiddenFor(modelItem => item.subscriber) %>
                </td>
            </tr>
            <% } %>
            <% ViewBag.subscribers = Model.subscribers; %>                                    probeersel
            <%= Html.HiddenFor(model => model.subscribers) %>                                 probeersel
        </table>
        <%} %>
        <%else
           { %>
        <p>
            No subscribers found.</p>
        <%} %>
        <input type="submit" value="Add Subscribers" />
    </div>
    </fieldset>
            <%} %>

Controller: SubscriberGroupController 控制器:SubscriberGroupController

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Security;
using Mail.Models;

namespace Mail.Controllers
{
    public class SubscriberGroupController : Controller
    {
        private int groupID;
        private MailDBEntities db = new MailDBEntities();
        //
        // GET: /SubscriberGroup/

        public ActionResult Index(int id)
        {
            groupID = id;
            MembershipUser myObject = Membership.GetUser();
            Guid UserID = Guid.Parse(myObject.ProviderUserKey.ToString());
            UserCustomer usercustomer = db.UserCustomers.Single(s => s.UserID == UserID);
            var subscribers = from subscriber in db.Subscribers
                              where (subscriber.CustomerID == usercustomer.CustomerID) | (subscriber.CustomerID == 0)
                              select new SubscriberCheckedModel { subscriber = subscriber, AddToGroup = false };
            SubscriberCheckedListViewModel test = new SubscriberCheckedListViewModel();
            test.subscribers = subscribers;
            return View(test);
        }



        [HttpPost]
        public ActionResult Index(string filter)
        {
            MembershipUser myObject = Membership.GetUser();
            Guid UserID = Guid.Parse(myObject.ProviderUserKey.ToString());
            UserCustomer usercustomer = db.UserCustomers.Single(s => s.UserID == UserID);
            var subscribers2 = from subscriber in db.Subscribers
                               where ((subscriber.FirstName.Contains(filter)|| subscriber.LastName.Contains(filter))
                               && (subscriber.CustomerID == usercustomer.CustomerID || subscriber.CustomerID == 0))
                               select new SubscriberCheckedModel { subscriber = subscriber, AddToGroup = false };
            SubscriberCheckedListViewModel test = new SubscriberCheckedListViewModel();
            test.subscribers = subscribers2.ToList();
            return View(test);
        }

        [HttpPost]
        public ActionResult AddToGroup(SubscriberCheckedListViewModel test)
        {
            //test is null 
            return RedirectToAction("Details", "Group", new { id = groupID });
        }


    }
}

ViewModel: SubscriberGroupModel ViewModel:SubscriberGroupModel

using System.Collections.Generic;
using Mail;
namespace Mail.Models
{
    public class SubscriberCheckedModel
    {
        public Subscriber subscriber { get; set; }
        public bool AddToGroup { get; set; }
    }

    public class SubscriberCheckedListViewModel
    {
        public IEnumerable<SubscriberCheckedModel> subscribers { get; set; }
    }
}

IEnumerable will not binded automatically, we need to modify the foreach loop in the view with follows, IEnumerable不会自动绑定,我们需要使用以下命令修改视图中的foreach循环,

<% for (int i=0;i<Model.subscribers.Count();i++) 
               { %> 
            <tr> 
                <td> 
                    <%= Html.CheckBoxFor(Model => Model.subscribers[i].AddToGroup)%> 
                </td> 
                <td> 
                    <%= Html.DisplayFor(Model =>  Model.subscribers[i].subscriber.LastName)%> 
                    <%= Html.ActionLink(Model.subscribers[i].subscriber.FirstName + " " + Model.subscribers[i].subscriber.LastName, "Details", new { id = Model.subscribers[i].subscriber.SubscriberID })%> 
                </td> 
                <td> 
                    <%: Html.DisplayFor(Model => Model.subscribers[i].subscriber.Email)%> 
                </td> 
                <td> 
                    <%: Html.DisplayFor(Model => Model.subscribers[i].subscriber.Customer.Company)%> 
                    <%= Html.HiddenFor(Model => Model.subscribers[i].subscriber) %> 
                </td> 
            </tr> 
            <% } %>

First Lets modify your model to have Id field 首先让我们修改您的模型以拥有ID字段

using System.Collections.Generic;
using Mail;
namespace Mail.Models
{
    public class SubscriberCheckedModel
    {
        public Subscriber subscriber { get; set; }
        public bool AddToGroup { get; set; }
    }

    public class SubscriberCheckedListViewModel
    {
        int GroupId{get;set;}
        public IEnumerable<SubscriberCheckedModel> subscribers { get; set; }
    }
}

Now lets modify controller, 现在让我们修改控制器,

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    using System.Web.Security;
    using Mail.Models;

    namespace Mail.Controllers
    {
        public class SubscriberGroupController : Controller
        {
            private int groupID;
            private MailDBEntities db = new MailDBEntities();
            //
            // GET: /SubscriberGroup/

            public ActionResult Index(int id)
            {
                groupID = id;
                MembershipUser myObject = Membership.GetUser();
                Guid UserID = Guid.Parse(myObject.ProviderUserKey.ToString());
                UserCustomer usercustomer = db.UserCustomers.Single(s => s.UserID == UserID);
                var subscribers = from subscriber in db.Subscribers
                                  where (subscriber.CustomerID == usercustomer.CustomerID) | (subscriber.CustomerID == 0)
                                  select new SubscriberCheckedModel { subscriber = subscriber, AddToGroup = false };
                SubscriberCheckedListViewModel test = new SubscriberCheckedListViewModel();
                test.subscribers = subscribers;
test.GroupId=groupID;
                return View(test);
            }



            [HttpPost]
            public ActionResult Index(string filter)
            {
                MembershipUser myObject = Membership.GetUser();
                Guid UserID = Guid.Parse(myObject.ProviderUserKey.ToString());
                UserCustomer usercustomer = db.UserCustomers.Single(s => s.UserID == UserID);
                var subscribers2 = from subscriber in db.Subscribers
                                   where ((subscriber.FirstName.Contains(filter)|| subscriber.LastName.Contains(filter))
                                   && (subscriber.CustomerID == usercustomer.CustomerID || subscriber.CustomerID == 0))
                                   select new SubscriberCheckedModel { subscriber = subscriber, AddToGroup = false };
                SubscriberCheckedListViewModel test = new SubscriberCheckedListViewModel();
                test.subscribers = subscribers2.ToList();
                return View(test);
            }

            [HttpPost]
            public ActionResult AddToGroup(SubscriberCheckedListViewModel test)
            {
                var id=test.GroupId; 
                return RedirectToAction("Details", "Group", new { id = groupID });
            }


        }

Now lets modify the view, 现在让我们修改视图

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.master" Inherits="System.Web.Mvc.ViewPage<Mail.Models.SubscriberCheckedListViewModel>" %>
…
<h2 class="common-box-title">
        Add Subscribers to Group</h2>
    <p>
        <% using (Html.BeginForm("Index", "SubscriberGroup"))
           { %>
            <input name="filter" id="filter" type="text" />
            <input type="submit" value="Search" />

        <%} %>
    </p>
            <% using (Html.BeginForm("AddToGroup", "SubscriberGroup", Model,FormMethod.Get, null))
           { %>
           <fieldset>
    <div style="display: inline-block; width: 70%; vertical-align: top;">
        <% if (Model.subscribers.Count() != 0)
           { %>
           <%: Html.HiddenFor(m=>m.GroupId) %>
        <table class="hor-minimalist-b">
            <tr>
                <th>
                    Add To Group
                </th>
                <th>
                    Full Name
                </th>
                <th>
                    Email
                </th>
                <th>
                    Customer
                </th>
            </tr>
            <% for (int i=0;i<Model.subscribers.Count();i++) 
               { %> 
            <tr> 
                <td> 
                    <%= Html.CheckBoxFor(M => M.subscribers[i].AddToGroup)%> 
                </td> 
                <td> 
                    <%= Html.DisplayFor(M =>  M.subscribers[i].subscriber.LastName)%> 
                    <%= Html.ActionLink(Model.subscribers[i].subscriber.FirstName + " " + Model.subscribers[i].subscriber.LastName, "Details", new { id = Model.subscribers[i].subscriber.SubscriberID })%> 
                </td> 
                <td> 
                    <%: Html.DisplayFor(M => M.subscribers[i].subscriber.Email)%> 
                </td> 
                <td> 
                    <%: Html.DisplayFor(M => M.subscribers[i].subscriber.Customer.Company)%> 
                    <%= Html.HiddenFor(M => M.subscribers[i].subscriber) %> 
                </td> 
            </tr> 
            <% } %>
            <% ViewBag.subscribers = Model.subscribers; %>                                    probeersel
            <%= Html.HiddenFor(model => model.subscribers) %>                                 probeersel
        </table>
        <%} %>
        <%else
           { %>
        <p>
            No subscribers found.</p>
        <%} %>
        <input type="submit" value="Add Subscribers" />
    </div>
    </fieldset>
            <%} %>

Give it a TRY.... 试试看....

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM