2012-04-02 60 views
0

嗨,我正在使用本指南here,我按照它。但我只使用搜索和分页。搜索和分页,但在搜索时仍然错误地显示错误的总页数

当我搜索的东西仍然显示16页,但它应该像3页。

这里的控制器代码:

public ActionResult Index(int page = 1,string search = null) 
    { 
     IEnumerable<Produkter> produkt = db.Produkter.Where(p => search == null 
      || p.Kategorie.Contains(search) 
      || p.Material.Contains(search) 
      || p.Namn.Contains(search) 
      || p.Storlek.Contains(search) 
      || p.Tillbehör.Contains(search) 
      || p.Tillbehörstyp.Contains(search) 
      || p.Benämning.Contains(search) 
      || p.Färg.Contains(search)); 

     ViewBag.TotalPages = (int)Math.Ceiling((double)db.Produkter.Count()/pageSize); 
     produkt = produkt.Skip((page - 1) * pageSize).Take(pageSize).ToList(); 

     ViewBag.CurrentPage = page; 
     ViewBag.PageSize = pageSize; 

     ViewBag.Search = search; 
     return View(produkt); 

这里是视图:

@model IList<Mvctest.Models.Produkter> 
@helper biuldLinks(int start, int end, string innerContent) 
{ 
    for (int i = start; i <= end; i++) 
    { 
    <a class="@(i == ViewBag.CurrentPage ? "current" : "")" href="@Url.Action("Index", "Produkter", new { Search = ViewBag.Search , page = i})">@(innerContent ?? i.ToString())</a> 
    } 
} 
@helper pageLinks() 
{ 
    exakly the same code on the giude 
} 

<div class="product-search"> 
<form action="@Url.Action("Index", "Produkter")" method="get"> 
Search <input id="search" name="search" type="text" value="@ViewBag.Search" /> 
<input type="submit" value="Search" /> 
</form> 

Page: 
@pageLinks() 

寻呼工作和搜索工作。问题是当我搜索分页时仍然会显示所有页面。在列出所有产品时,总共只有16页,但在搜索时应该只有3页。

回答

0

当你做你算不算过滤列表

ViewBag.TotalPages = (int)Math.Ceiling((double)db.Produkter.Count()/pageSize); 

尝试

ViewBag.TotalPages = (int)Math.Ceiling((double)produkt.Count/pageSize); 
+0

THX更换。嗨,我还有一个问题。 || p.Benämning.Contains(搜索) || p.Färg.Contains(搜索)|| 。p.price.ToString()包含(搜索));但数据库中的价格是货币价值。但我把它转换。它说ViewBag.TotalPages =(int)Math.Ceiling((double)produkt.Count()是不是一个类型。:( – newb 2012-04-02 13:19:48

+0

应该工作。我现在没有VS2010,但也许我的错误是你必须删除'()'唯一的produkt.Count – Iridio 2012-04-02 16:39:21