[英]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.