我试图在MVC控制器中实现过滤和分页。我使用ViewBag将信息传递给View。将过滤器作为查看对象传递给控制器
Filter类是这样的:
public class Criteria
{
public int? SnapshotKey { get; set; }
public string Delq { get; set; }
public override string ToString()
{
string[] Ares = new string[2];
if (SnapshotKey.HasValue)
Ares[0] = "SnapshotKey=" + SnapshotKey.ToString();
if (!String.IsNullOrWhiteSpace(Delq))
Ares[1] = "Delq=" + Delq;
return String.Join("&", Ares.Where(s => !string.IsNullOrWhiteSpace(s)));
}
}
我控制器的方法是这样的:
public ActionResult Search(Criteria filter, string filterString,
int pageNo = 1, int pageSize = 5)
{
using (DemoDBEntities db = new DemoDBEntities())
{
var list = db.BMH.AsQueryable();
if (filter != null)
{
if (filter.SnapshotKey.HasValue)
list = list.Where(r => r.SnapshotKey == filter.SnapshotKey.Value);
if (!String.IsNullOrWhiteSpace(filter.Delq))
list = list.Where(r => r.Delq == filter.Delq);
}
list = list.OrderBy(r=>r.SnapshotKey).Skip((pageNo - 1) * pageSize).Take(pageSize);
ViewBag.Criteria = filter.ToString();
ViewBag.CriteriaString = filterString;
ViewBag.PageNo = pageNo;
return View(list.ToList());
}
}
据我所知,我无法通过ViewBag作为一个对象来控制,这就是为什么我用filter.ToString( )来存储当前的过滤器。
在视图中,我有以下链接转到特定页面,同时保留当前过滤器。
@Html.ActionLink("Next Page", "Search", new { filter = ViewBag, filterString = ViewBag.CriteriaString, pageNo = ViewBag.PageNo + 1, pageSize = 5 })
所以当从View返回时,我得到当前的过滤器作为字符串。现在在控制器中,我需要将字符串转换为Criteria类。这是可行的,但我正在寻找一个更体面的方式来做我所需要的。
为什么不只是'新{SnapshotKey = ViewBag.SnapshotKey,Delq = ViewBag.Delq,帮您做生意= ViewBag.PageNo + 1 ...}'(你可以通过在模型中添加'pageNo'和'pageSize'来简化它,所以POST方法只是'public ActionResult Search(Criteria filter)' –
我试图不依赖如果我在Criteria类中添加了一个新字段,这是否有意义呢? – FLICKER
好吧,如果你添加一个新字段,那么你需要更新'.ToString()'方法(即有些东西需要更新)。你总是可以将'pageNo'和'pageSize'添加到'Criteria'模型中,并将它们包含在'ToString()'方法中,然后使用'Next Page' –