zoukankan      html  css  js  c++  java
  • ASP.NET MVC- 使用PageList.Mvc分页

      ASP.NET MVC中进行分页的方式有多种,在NuGet上有提供使用PagedList、PagedList.Mvc进行分页。

      1. 通过NuGet引用PagedList.Mvc

      在安装引用PagedList.Mvc的同时会安装引用PagedList。

      1.看一下Controller页面的代码,最后就简单的一句,将List数据ToPagedList返回过去就可以了。原来爱怎么分页可以怎么分页。

    //引用
    using PagedList;
    namespace MvcApplication1.Controllers
    {
        public class SplitPageController : Controller
        {
            //
            // GET: /SplitPage/
    
            public ActionResult Index(int page = 1)
            {
                //取数据
                List<Package.Model.Message> lists = new List<Package.Model.Message>();
                MessageDal message = new MessageDal();
                DataSet ds = message.GetList(" 1=1 ");
    
                //转成List
                for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
                {
                    lists.Add(new Package.Model.Message()
                    {
                        gName = ds.Tables[0].Rows[i]["gName"].ToString(),
                        gContent = ds.Tables[0].Rows[i]["gContent"].ToString()
                    });
                }
    
                //将数据分页后返回页面(这里可以在取数据的时候先分页后,再使用ToPagedList实现分页
                return View( lists.ToPagedList(page, 2));
            }
    
        }
    }

      返回后在HTML页面的显示

    @model PagedList.IPagedList<Package.Model.Message>
    @using PagedList.Mvc;
    
    @{
        Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
    </head>
    <body>
        <table>
            <tr>
                <th>
                    gname
                </th>
                <th>
                    gContent
                </th>
                <th>
    
                </th>
            </tr>
            @foreach (var item in Model)
            {
                <tr>
                    <td>
                        @Html.DisplayFor(modelItem => item.gName)
                    </td>
                    <td>
                        @Html.DisplayFor(modelItem => item.gContent)
                    </td>
                    <td></td>
                </tr>
            }
        </table>
        @Html.PagedListPager(Model, page => Url.Action("Index", new { page }))
    </body>
    </html>

      使用ViewBag返回分页数据,由于MODEL只有一个,如果按官网给的例子,那么一个页面只能有一个分页了,但是VIEWBAG点出来的却可以多个。

    看一下显示,不多说了,直接上代码

      CONTROLLER页面

    using PagedList;
    
    namespace MvcApplication2.Controllers
    {
        public class HomeController : Controller
        {
            //
            // GET: /Home/
    
            public ActionResult Index(int page = 1)
            {
                //取数据
                List<Package.Model.Message> lists = new List<Package.Model.Message>();
                MessageDal message = new MessageDal();
                DataSet ds = message.GetList(" 1=1 ");
    
                //转成List
                for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
                {
                    lists.Add(new Package.Model.Message()
                    {
                        gName = ds.Tables[0].Rows[i]["gName"].ToString(),
                        gContent = ds.Tables[0].Rows[i]["gContent"].ToString()
                    });
                }
    
                //将数据分页后返回页面(这里可以在取数据的时候先分页后,再使用ToPagedList实现分页
                ViewBag.MyPageList = lists.ToPagedList(page, 2);
                return View( );
            }
    
        }
    }

      VIEW视图

    @using PagedList.Mvc;
    
    @{
        PagedList.IPagedList<Package.Model.Message> myPageList = (PagedList.IPagedList<Package.Model.Message>)ViewBag.MyPageList;
        Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <link href="~/Content/PagedList.css" rel="stylesheet" />
        <title>Index</title>
    </head>
    <body>
        <table>
            <tr>
                <th>
                    gname
                </th>
                <th>
                    gContent
                </th>
                <th>
    
                </th>
            </tr>
            @foreach (var item in myPageList)
            {
                <tr>
                    <td>
                        @Html.DisplayFor(modelItem => item.gName)
                    </td>
                    <td>
                        @Html.DisplayFor(modelItem => item.gContent)
                    </td>
                    <td></td>
                </tr>
            }
        </table>
        每页 @myPageList.PageSize 条记录,共 @myPageList.PageCount 页,当前第 @myPageList.PageNumber 页
        @Html.PagedListPager(myPageList, page => Url.Action("Index", new { page }))
    </body>
    </html>

      参考这个原文:http://www.cnblogs.com/libingql/p/3486554.html

  • 相关阅读:
    有关远程设置的问题
    QT使用tableWidget显示双排列表 而且选中用红框圈出来
    一个程序猿的跨洋找工作分享
    linux块设备的IO调度算法和回写机制
    基于servlet实现一个web框架
    Java中的条件编译(转)
    Android NDK 使用第三方静态库(转)
    Android 使用动态库或静态库来编译生成动态库(转)
    Android应用运行过程(转)
    android NDK编译(导入).a文件和编译多个so文件(转)
  • 原文地址:https://www.cnblogs.com/cxeye/p/4957891.html
Copyright © 2011-2022 走看看