关于在Core2.0中PagedListCore实现分页

一、引言

  开发中在对大量数据展示的时候,出于对性能的考虑,我们往往是使用分页功能(用户需要那一页我们就返回给他那一页,而不是一次性加载所有的数据)。传统的.Net Framework中我们可以使用名为PagedList包来进行分页功能的实现,而在Core2.0中我们也可以使用PagedListCore来进行分页,今天在这里就为大家演示PagedListCore的使用。

二、添加NuGet包的引用

  首先在Core2.0的程序中PagedList.Core.Mvc(V1.1.0)。(嗯。。。第一个这Logo图片我喜欢)

 

                                  

三、数据的封装 (这里使用模拟的假数据)

    public class InitDataFisrt
{ /// <summary>
/// 排序按需查询
/// </summary>
/// <param name="pageIndex">页号</param>
/// <param name="pageSize">页的大小</param>
/// <param name="totalCount">总量</param>
/// <returns></returns>
public static List<Student> GetStudents(int pageIndex, int pageSize, ref int totalCount)
{
var Students = setStudentList()
.OrderByDescending(o => o.ID)
.Skip((pageIndex - ) * pageSize)
.Take(pageSize).ToList();
return Students;
} /// <summary>
/// 初始化数据 50条
/// </summary>
private static List<Student> setStudentList()
{
List<Student> list = new List<Student>();
for (int i = ; i < ; i++)
{
Student stu = new Student()
{
Name = $"第{i}个人",
Address = $"xx小区第{i}单元",
Phone = $"{i}",
Sex = "男",
ClassID = i,
ID = i
};
list.Add(stu);
} return list;
}
}

四、编写Home控制器的Index页面

 public class HomeController : Controller
{
/// <summary>
///
/// </summary>
/// <param name="page">要跳转的页面</param>
/// <param name="parameterTest1">传多个参数时</param>
/// <param name="parameterTest2">传多个参数时</param>
/// <returns></returns>
public IActionResult Index(int? page,int parameterTest1,int parameterTest2)
{
//第一次访问时 返回的一页
int pageIndex = page ?? ;
int pageSize = ;
int totalCount = ; //假装是从数据库得到的数据
List<Student> list = InitDataFisrt.GetStudents(pageIndex, pageSize, ref totalCount); //将List转换成分页时需要的IpagedList
IPagedList<Student> pagedList = new StaticPagedList<Student>(list, pageIndex, pageSize,totalCount); return View(pagedList);
}
}

五、前台的对数据的展示(还没开始处理分页,因为要使用到TagHelpers的需要进行封装)

@{
ViewData["Title"] = "Home Page";
}
@model PagedList.Core.StaticPagedList<Student> <div id="myCarousel" class="carousel slide" data-ride="carousel" data-interval="">
<table>
<thead>
<tr>
<td>编号</td>
<td>姓名</td>
<td>地址</td>
<td>电话</td>
<td>性别</td>
<td>班级</td>
</tr>
</thead>
<tbody>
@foreach (var item in Model)
{
<tr>
<td>@item.ID</td>
<td>@item.Name</td>
<td>@item.Address</td>
<td>@item.Phone</td>
<td>@item.Sex</td>
<td>@item.ClassID</td>
</tr>
}
</tbody>
</table>
</div>

六、封装PagedListCore的TagHelpers(下面是他的官网,开源在GitHub)

https://github.com/hieudole/PagedList.Core.Mvc

1、在Views文件下的_ViewImports中添加如下代码:

@using PagedListCoreTest
@using PagedListCoreTest.Models
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
@addTagHelper *, PagedList.Core.Mvc

2、再次编写Index.cshtml文件如下:

@{
ViewData["Title"] = "Home Page";
//封装的分页样式 在下一步会提出
var PagedListRenderOptions = PageListOptions.GetPagedListRenderOptions; //如果有多个参数(parameterTest1,parameterTest2) 除了默认的page
//如: public IActionResult Index(int? page,int parameterTest1,int parameterTest2)
//可通过new Dictionary<string,string>
//Key,Value皆为string => 会通过Key自动匹配后台的参数名
//用法 见下方代码
var RouteData = new Dictionary<string, string>();
RouteData.Add("parameterTest1", "参数一");
RouteData.Add("parameterTest2", "参数二");
}
@model PagedList.Core.StaticPagedList<Student> <div id="myCarousel" class="carousel slide" data-ride="carousel" data-interval="">
<table>
<thead>
<tr>
<td>编号</td>
<td>姓名</td>
<td>地址</td>
<td>电话</td>
<td>性别</td>
<td>班级</td>
</tr>
</thead>
<tbody>
@foreach (var item in Model)
{
<tr>
<td>@item.ID</td>
<td>@item.Name</td>
<td>@item.Address</td>
<td>@item.Phone</td>
<td>@item.Sex</td>
<td>@item.ClassID</td>
</tr>
}
</tbody>
</table> @*
options:分页的样式
asp-controller:控制器名
asp-action:Action名
asp-all-route-data:不加该项时 =》会默认添加Page参数
如若需要额外传参数
通过字典传Dictionary,
类型为Dictionary<string, string>
*@
<pager list="@Model" options="@PagedListRenderOptions" asp-controller="Home" asp-action="Index" asp-all-route-data="RouteData" />
</div>

4、封装options所需要的PagedListRenderOptions类,在Model下添加PageListOptions类 引用using PagedList.Core.Mvc,封装PagedListRenderOptions属性

更多关于PagedListRenderOptions的配置(GitHub导航)

using PagedList.Core.Mvc;
using System;
using System.Collections.Generic;
using System.Text; namespace PagedListCoreTest.Models
{
/// <summary>
/// 封装的PagedList.MVC.Core样式
/// </summary>
public static class PageListOptions
{
//获取配置
public static PagedListRenderOptions GetPagedListRenderOptions
{
get{
return new PagedListRenderOptions()
{
//添加省略号,其中不显示所有页码
DisplayEllipsesWhenNotShowingAllPageNumbers = true,
//Previous的超链接
LinkToPreviousPageFormat = "上一页",
//Next的超链接
LinkToNextPageFormat = "下一页",
//如果设置为Always,则渲染指向列表中第一页的超链接。
            //如果设置为IfNeeded,则仅在第一页在分页控件中不可见时呈现超链接
DisplayLinkToFirstPage = PagedListDisplayMode.IfNeeded,
//如果设置为Always,则渲染指向列表中最后一页的超链接。
            //如果设置为IfNeeded,则仅在最后一页在分页控件中不可见时呈现超链接。
DisplayLinkToLastPage = PagedListDisplayMode.IfNeeded,
//如果设置为Always,则渲染指向列表上一页的超链接。
            //如果设置为IfNeeded,则仅当列表中有上一页时才渲染超链接。
DisplayLinkToPreviousPage = PagedListDisplayMode.Always,
//如果设置为Always,则渲染指向列表下一页的超链接。
            //如果设置为IfNeeded,则仅在列表中有下一页时呈现超链接。
DisplayLinkToNextPage = PagedListDisplayMode.Always,
//如果为true,则包含列表中每个页面的超链接。
DisplayLinkToIndividualPages = true,
//指定要附加第一个列表项的CSS类。
ClassToApplyToFirstListItemInPager = "previous",
//最后一个的样式
ClassToApplyToLastListItemInPager = "next",
};
}
}
}
}

七、最后在Startup.cs的ConfigureServices中注册PagedList.Core.Mvc需要的实例

  //注册PagedList.Core.Mvc需要的实例
services.AddSingleton<IActionContextAccessor, ActionContextAccessor>();

八、效果

PagedListCore的使用的更多相关文章

随机推荐

  1. scala中Trait简单使用

    trait Log { def log(message:String) = println("log:" + message) } /** * 为实例混入trait * */ tr ...

  2. C/C++ 无法解析的外部符号解决方案

    { //0 类的成员函数没有实现就调用 //1 调用没有编译生成cpp 的函数 //2 没有加载lib //3 最重要的就是有声明无实现 }

  3. SQL SERVER中[dbo]的解释

    1.作用: (1)DBO是每个数据库的默认用户,具有所有者权限,即DbOwner:通过用DBO作为所有者来定义对象,能够使数据库中的任何用户引用而不必提供所有者名称.(2)至于为什么要使用所有者进行限 ...

  4. 大转盘抽奖css3+js(简单书写)

    今天花了一段时间简单写了下抽奖大转盘,这里写的只是自己想到的简单的写了下(也希望收获其他想法),后续,再写的话会更新. 大体思路:页面加载完成后,通过监听开始按钮的点击事件.然后会根据产生的随机数,通 ...

  5. NX二次开发-获取切换按钮的当前状态UF_MB_ask_toggle_state

    NX9+VS2012 1.打开D:\Program Files\Siemens\NX 9.0\UGII\menus\ug_main.men 找到装配和PMI,在中间加上一段 TOGGLE_BUTTON ...

  6. 牛客多校第九场 B Quadratic equation 模平方根

    题意: 已知 $x+y$ $mod$ $q = b$ $x*y$ $mod$ $q = c$ 已知b和c,求x和y 题解: 容易想到$b^2-4c=x^2-2xy+y^2=(x-y)^2$ 那么开个根 ...

  7. Hadoop2.X主要模块默认端口及作用

    Hadoop集群的各部分一般都会使用到多个端口,有些是daemon之间进行交互之用,有些是用于RPC访问以及HTTP访问.而随着Hadoop周边组件的增多,完全记不住哪个端口对应哪个应用,特收集记录如 ...

  8. Scala 可变长参数

    Scala 允许你指明函数的最后一个参数可以是重复的.这可以允许客户向函数传入可变长度参数列表.想要标注一个重复参数,在参数的类型之后放一个星号. 例如:定义一个可变参数的函数param def pa ...

  9. vim 命令行模式 操作指令

      复制n行: nyy 粘贴:p 剪切(删除)n行: ndd 剪切 ( 删除 ) n个字符:nx 移动光标到第一行 : gg 移动光标到最后一行 : G 设置格式  :gg=G 返回上一次操作前(撤销 ...

  10. JS事件 失焦事件(onblur)onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序。

    失焦事件(onblur) onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序. 如下代码, 网页中有用户和密码两个文本框.当前光标 ...