(家庭作业)MVC分页帮助

时间:2011-01-11 21:01:44

标签: asp.net-mvc pagination

我正在尝试使用ASP.NET MVC组合一个非常简单的应用程序,它显示新闻文章并对它们进行分页。我有点中途,但需要帮助整理分页并使其与搜索查询一起使用。

这是我的HomeController:

public ActionResult Index(String query, int? page)
{
        // limit the number of articles per page
        const int pageSize = 4;
        // build the query
        var ArticleQuery = from a in _db.ArticleSet select a;
        // check if their is a query
        if (!string.IsNullOrEmpty(query))
        {
            ArticleQuery = ArticleQuery.Where(a => a.headline.Contains(query));
        }
        // orders the articles
        var OrderedArticles = ArticleQuery.OrderByDescending(a => a.posted);
        // takes the ordered articles and paginates them
        //var paginatedArticles = new PaginatedList(OrderedArticles.Skip((page ?? 0) * pageSize).Take(pageSize), page ?? 0, pageSize);
        var paginatedArticles = new PaginatedList<Article>(OrderedArticles, page ?? 0, pageSize);
        // return the paginated articles to the view
        return View(paginatedArticles);
}

这个想法是Controller每页显示4个项目将按日期排序。以下是我对Index方法的看法:

<ul id="pagination">
    <% if (Model.PreviousPage) { %>
        <li><%= Html.ActionLink("<< First Page", "Index")%></li>
        <li><%= Html.ActionLink("<< Previous Page", "Index", new { page=(Model.PageIndex-1) }) %></li>
    <% } %>
    <% if (Model.NextPage) { %>
        <li><%= Html.ActionLink("Next Page >>", "Index", new { page = (Model.PageIndex + 1) })%></li>
        <li><%= Html.ActionLink("Last Page >>", "Index", new { page = (Model.TotalPages - 1) })%></li>
    <% } %>    
</ul>

这个想法是这两个分页链接只会显示条件是否为真。

最后,这是寻呼机的PaginatedList类:

    using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;

namespace NewsApp.Models
{
    public class PaginatedList<T> : List<T>
    {
        public int PageIndex { get; private set; }
        public int PageSize { get; private set; }
        public int TotalCount { get; private set; }
        public int TotalPages { get; private set; }

        public PaginatedList(IQueryable<T> source, int pageIndex, int pageSize)
        {
            PageIndex = pageIndex;
            PageSize = pageSize;
            TotalCount = source.Count();
            TotalPages = (int)Math.Ceiling(TotalCount / (double)PageSize);

            this.AddRange(source.Skip(PageIndex * PageSize).Take(PageSize));
        }
        public bool HasPreviousPage
        {
            get
            {
                return (PageIndex > 0);
            }
        }
        public bool HasNextPage
        {
            get
            {
                return (PageIndex + 1 < TotalPages);
            }
        }
    }

注意:我不想使用像MVCContrib等任何第三方组件,因为这是针对大学的任务,所以会破坏目的。

现在分页工作正常,但是当我进行搜索时,例如/?query = test我希望能够在丢失的那一刻分页结果:/

感谢。

1 个答案:

答案 0 :(得分:2)

你没有引用你的实际错误,但我认为我看到了什么错误:

这两行将返回包含结果的IEnumerable。

var paginatedArticles = OrderedArticles.Skip((page ?? 0) * pageSize).Take(pageSize).ToList();

return View(paginatedArticles);

但是,根据您发布的视图和帮助程序类,您认为PaginatedList对象是其模型。

如果是这种情况,我会执行以下操作(更新):

var paginatedArticles = new PaginatedList( OrderedArticles, page ?? 0, pageSize );

return View(paginatedArticles);

然后您的视图应该返回适​​当的模型。

说:我不知道你为什么不使用存储库层,但除非你的应用只是一个页面,否则最好有一个到位。

更新 - 我认为完整的控制器逻辑应该是:

public ActionResult Index(String query, int? page)
{
    const int pageSize = 4;

    var ArticleQuery = from m in _db.ArticleSet select m;

    // Searching
    if (!string.IsNullOrEmpty(query))
    {
        ArticleQuery = ArticleQuery.Where(m => m.headline.Contains(query));
    }

    var OrderedArticles = ArticleQuery.OrderByDescending(m => m.posted);

    var paginatedArticles = new PaginatedList( OrderedArticles, page ?? 0, pageSize );
    // this will now be of type paginatedList. this class handles all of the paging for you, so no need to do that ahead of time

    return View(paginatedArticles);
}

在这种情况下,PaginatedList不是帮助者 - 需要创建并传递给模型的完整类。严格定义单词的帮助程序的完成方式大不相同,在这种情况下可能不适用。