zoukankan      html  css  js  c++  java
  • MVC中分页的实现

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

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

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

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

    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中,也需要加入对包的引用:

    同时需要在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。

  • 相关阅读:
    简单理解ThreadLocal原理和适用场景
    Portal实现原理
    Spring cloud微服务实战——基于OAUTH2.0统一认证授权的微服务基础架构
    Java8中 Date和LocalDateTime的相互转换
    sonar rule
    图论篇2——最小生成树算法(kurskal算法&prim算法)
    图论篇1——图的基本概念
    数论篇6——欧拉函数
    数论篇5——数论四大定理
    数论篇4——逆元(数论倒数)
  • 原文地址:https://www.cnblogs.com/HelpQY/p/3873420.html
Copyright © 2011-2022 走看看