码迷,mamicode.com
首页 > Web开发 > 详细

MVC中分页的实现

时间:2014-07-29 10:45:46      阅读:264      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   使用   strong   io   2014   

我在格斗人网 (www.helpqy.com) 中使用了下面的分页技术。

分页可以采用troygoode提供的开源包,其开源网站主页为:https://github.com/TroyGoode/PagedList。具体使用方法如下所示:

1. 通过NuGet下载PagedList.Mvc包,这个包会自动下载另外一个包PagedList,如下所示:

bubuko.com,布布扣

 

bubuko.com,布布扣

2. 在controller中引入以上两个包,如下所示:

bubuko.com,布布扣

 

3. 在controller中的ActionResult函数中按照如下最小结构进行调用:

1 ActionResult ExampleFunction (int ? page)
2 {
3     int pageSize = 10;
4     int pageNumber = page ?? 1;
5     
6     return View(ExampleList.ToPagedList(pageNumber, pageSize));
7 }

    其中,page是可以为空的整型,表示View下一次访问时应该处于第几页,由View通过get方式传过来,第一次访问页面时,page为空,则pageNumber被赋值为1,表示为第一页内容。pageSize是每一页显示的条目数,pageNumber表示希望显示的是第几页。ToPagedList方法实际上是将ExampleList的所有条目按照pageSize的大小重新组合成页,然后通过pageNumber来指示显示那一页,并仅将这一页的内容传递到View中。

 

4. 在ExampleFunction对应的View中,也需要加入对包的引用:

bubuko.com,布布扣

同时需要在View顶部加入model引用,将ToPagedList的结果转换成IPagedList集合:

@model IPagedList<ExampleObject>

 

5. 在ExampleFunction对应的View中,按照如下的最小结构在页面底部调用:

Page @(Model.PageCount < Model.PageNumber ? 0 : Model.PageNumber) of @Model.PageCount
@Html.PagedListPager(Model, page => Url.Action("ExampleFunction", new { page = page}))

    其中,第一行代码显示目前处于第几页,总共多少页。第二行代码自动根据总条目数和每一页的条目数进行计算,从而显示页码。同时,第二行代码自动生成每一个页码对本View的get访问链接,当用户点击某一页码时,实际上是在继续访问本View,只不过将page参数,也就是被点击的页码传递给了Controller中的ExampleFunction函数,指示希望Controller把某一页的内容传递给View,如此再回过头去看Controller中Example函数的分析就比较清楚了。Model就是在View顶部所转化的IPagedList。

bubuko.com,布布扣

 

MVC中分页的实现,布布扣,bubuko.com

MVC中分页的实现

标签:style   blog   http   color   使用   strong   io   2014   

原文地址:http://www.cnblogs.com/HelpQY/p/3873420.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!