一、前言:

分页功能在项目中时常用到,一款可以快速实现分页功能的插件非常有必要,pagination--这款插件功能非常完美,几乎我所有项目中使用到分页的地方都会第一时间考虑到这个插件,但是其实有能力的同学最好还是使用原生的JS或者JQuery来开发分页功能,毕竟插件很多源码比较复杂,也并不是所有功能都做到尽善尽美,仅仅是提供一个方便而已。

二、具体使用方法:

(1)第一步,导入jquery和pagination.js

<script src="jquery.js"></script>
<script src="jquery.pagination.js"></script>

(2)第二步,HTML代码:

非常简单只需要一个div标签

<div class="M-box"></div>

(3)第三步,  JS代码:

$('.M-box').pagination({
pageCount:50,
jump:true,
coping:true,
homePage:'首页',
endPage:'末页',
prevContent:'上页',
nextContent:'下页'
});

如图所示:

三、核心参数方法

使用方法是:

$('.M-box').pagination({option})

option的参数如下:

pageCount 9 总页数
totalData 0 数据总条数
current 1 当前第几页
showData 0 每页显示的条数
prevCls 'prev' 上一页class
nextCls 'next' 下一页class
prevContent '<' 上一页节点内容
nextContent '>' 下一页节点内容
activeCls 'active' 当前页选中状态class名
count 3 当前选中页前后页数
coping false 是否开启首页和末页,值为boolean
isHide false 总页数为0或1时隐藏分页控件
keepShowPN false 是否一直显示上一页下一页
homePage '' 首页节点内容,默认为空
endPage '' 尾页节点内容,默认为空
jump false 是否开启跳转到指定页数,值为boolean类型
jumpIptCls 'jump-ipt' 文本框内容
jumpBtnCls 'jump-btn' 跳转按钮class
jumpBtn '跳转' 跳转按钮文本内容
callback function(){} 回调函数,参数"index"为当前页

其中回调函数是最核心的参数,即点击分页的数字按钮时所执行的操作,回调函数中有一个参数叫api

callback:function(api){

//回调函数。。。

}

该api接口的方法有如下:

方法                                参数                           说明

getPageCount()               无                         获取总页数

setPageCount(page)      page:页数           设置总页数

getCurrent()                    无                           获取当前页

filling()                             无                         填充数据,参数为页数

四、AJAX动态分页

其实做分页最主要的就是通过AJAX来动态获取数据后进行分页显示,我们要明白的是,为什么分页??

首页,因为数据库的数据是不可估量的,如果某一个系统的数据库数据有几千条甚至几万条,难道一个网页要把全部的数据都全部的展示出来吗??那肯定是不合理的,因为这非常消耗系统内存和网络带宽,我们肯定都是在AJAX请求数据时,传入了要显示的条数和页数,服务器在根据条数和页数返回数据给我们,比如我们要显示10条数据,显示第一页的内容,那服务器就相应的把该条件下的数据传回给我们,仅仅10条,这对于数据库和网页显示来说毫无压力。所以这就有了分页功能的出现。如果有50条数据,每页只显示10条数据,那理所当然的就是有5页了,那问题又来了,难道这个分页怎么知道我每个页数需要显示什么内容呢???是我全部加载数据后平均分配到每一页10条数据,然后依次显示下去吗??当然不是,我每当点击页数按钮的时候都要去加载数据,重新发起AJAX请求到服务器,然后返回数据给我们,那我们就大概知道怎么使用这个分页功能了!!

(1).首页,你得知道你分页按钮上需要显示几页吗??例如5页的话就是5个按钮。

所以首先必须使用AJAX请求得到所有数据的长度是多少,例如:  总共50条数据,我需要每页显示10条数据,当前 显示第一页的数据。

$.ajax({

url:...

type:"post",

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//data.length  就是数据的长度 ,也就是上面的10,具体参数名看你们服务器的返回叫什么

//data.count   是数据的总长度,也就是50,具体参数名看你们服务器的返回叫什么

}

})

(2).然后我在success方法中写入pagination的方法进行分页

$.ajax({

url:...

type:"post",

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//获取总条数
var sumCount=data.count;

//获取返回的条数

var count=data.length;

//重要的一步来了,需要获取我们按钮的个数,也就是分多少页,需要总条数除以返回数在向上取整

var pageCount=Math.ceil(sumCount/count);  //这里50除以10等于5,所以一共有5页

$('.M-box').pagination({
               pageCount:pageCount, //总页数
               coping:true,//是否开启首页和尾页
               homePage:'首页',
               endPage:'末页',
               prevContent:'上页',
               nextContent:'下页',
               current:1,  //当前第几页
               callback:function(api){  //按钮、回调函数

}

});

}

})

(3).现在最最关键的来了,就是分页中的回调函数的操作,也就是点击按钮需要做什么??上面第四点中分析到,点击按钮需要重新发起AJAX请求,需要把显示条数和当前的页数传回给服务器

$.ajax({

url:...

type:"post",

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//获取总条数
var sumCount=data.count;

//获取返回的条数

var count=data.length;

//获取分页数

var pageCount=Math.ceil(sumCount/count);  //这里50除以10等于5,所以一共有5页

$('.M-box').pagination({
               pageCount:pageCount, //总页数
               coping:true,//是否开启首页和尾页
               homePage:'首页',
               endPage:'末页',
               prevContent:'上页',
               nextContent:'下页',
               current:1,  //当前第几页
               callback:function(api){  //按钮、回调函数

//再次发起AJAX请求

$.ajax({

url:...

type:"post",

data:{

rows: 10, //依然显示10条数据

page: api.getCurrent()// 非常关键的一步,这里就要用到api接口的方法中获取当前页

的方法了,比如我点击第二页,当前页就是2,点击第三页,

当前页就是3,

}

success:function(data){

//ajax成功后的回调。。。

}

})

}

});

}

})

以上基本的一个流程就是这样。具体一些api方法和参数可以去试试。

一个很主要的流程就是,首先要发起ajax得到总条数和返回的条数然后在success回调中使用pagination的方法,在callback回调中再次发起ajax,就是为了点击分页按钮再次显示数据。

下载地址  "http://www.jq22.com/jquery-info5697"

声明:转自“http://blog.csdn.net/baidu_25343343/article/details/70478467

一款不错的jQuery分页插件--pagination的更多相关文章

  1. ajax 分页(jquery分页插件pagination) 小例1

    <link rel="stylesheet" href="/plugins/jQuery/page/pagination.css"/> <sc ...

  2. ajax 分页(jquery分页插件pagination) 小例3

    <#macro ajaxPaginte url > <script type="text/javascript"> var PageSize = 10;// ...

  3. jQuery分页插件pagination的用法

    https://www.zhangxinxu.com/jq/pagination_zh/ 参数: 参数名 描述 参数值 maxentries 总条目数 必选参数,整数 items_per_page 每 ...

  4. ajax 分页(jquery分页插件pagination) 小例2

    封装成:myPagination.js// ajax分页 function sendAjax(flag, dataParam, url, callback) {//封装的ajax: var shus ...

  5. jquery分页插件pagination

    参考1:https://www.cnblogs.com/jingping/p/3925976.html 参考2:https://segmentfault.com/a/1190000014487357 ...

  6. Jquery前端分页插件pagination使用

    插件描述:JqueryPagination是一个轻量级的jquery分页插件.只需几个简单的配置就可以生成分页控件.并且支持ajax获取数据,自定义请求参数,提供多种方法,事件和回调函数,功能全面的分 ...

  7. Jquery 分页插件 Jquery Pagination

    Jquery 分页插件 Jquery Pagination 分页插件来说,我觉得适用就行,尽量简单然后能够根据不同的应用场景能够换肤.展现形式等. 对于初学者想写分页插件的同学,也可以看下源码,代码也 ...

  8. Jquery前端分页插件pagination同步加载和异步加载

    上一篇文章介绍了Jquery前端分页插件pagination的基本使用方法和使用案例,大致原理就是一次性加载所有的数据再分页.https://www.jianshu.com/p/a1b8b1db025 ...

  9. 20个jQuery分页插件和教程

    1.客户端的jQuery 分页插件jPages jPages 是一个客户端的分页插件,但提供很多特性例如自动翻页.键盘和滚动浏览,延迟显示以及完全可定制的导航面板. Read More Demo 2. ...

随机推荐

  1. 01 lucene基础 北风网项目培训 Lucene实践课程 系统架构

    Lucene在搜索的时候数据源可以是文件系统,数据库,web等等. Lucene的搜索是基于索引,Lucene是基于前面建立的索引之上进行搜索的. 使用Lucene就像使用普通的数据库一样. Luce ...

  2. cdoj914-方老师分身 I 【dijkstra】

    http://acm.uestc.edu.cn/#/problem/show/914 方老师分身 I Time Limit: 3000/1000MS (Java/Others)     Memory ...

  3. linux ifconfig显示 command not found

    本人装的是centos7 想看下网络配置 结果显示如图: 正常情况下 ifconfig  是在超级管理员 的所属的目录 sbin/下的命令 现在来查看该目录下. 没有找到,别急 用 yum  sear ...

  4. ActiveMQ 使用文档

    一.为什么使用ActiveMQ 在总线的设计中可能会使用到JMS(Java Message Service)通道, Java消息服务(JMS)超越了生产商专有的MOM(Message-Oriented ...

  5. IIS “另一个程序正在使用此文件,进程无法访问"

    重启iis,提示"另一个程序正在使用此文件,进程无法访问".一开始就怀疑是80端口被占用,修改iis的端口为其它端口,重启iis, 果然成功. 在命令行,netstat -nabo ...

  6. Java工具类之Apache的Commons Lang和BeanUtils

    Apache Commons包估计是Java中使用最广发的工具包了,很多框架都依赖于这组工具包中的一部分,它提供了我们常用的一些编程需要,但是JDK没能提供的机能,最大化的减少重复代码的编写. htt ...

  7. code1796 社交网络

    输入描述 Input Description 输入文件中第一行有两个整数,n 和 m,表示社交网络中结点和无向边的数 目.在无向图中,我们将所有结点从 1 到 n 进行编号. 接下来 m 行,每行用三 ...

  8. Python爬虫实战八之利用Selenium抓取淘宝匿名旺旺

    更新 其实本文的初衷是为了获取淘宝的非匿名旺旺,在淘宝详情页的最下方有相关评论,含有非匿名旺旺号,快一年了淘宝都没有修复这个. 可就在今天,淘宝把所有的账号设置成了匿名显示,SO,获取非匿名旺旺号已经 ...

  9. toFixed

    1,toFixed要使用与Number数据类型 2.parseInt将字符串转换为整形 3.parseFloat将字符串转换为浮点型

  10. gitlab centos 安装配置运维笔记

    写在前面 如果你需要一个git服务器,为企业或自己的团队托管代码而又不希望将代码仓库存储到第三方.你可以在自己的服务器上搭建一个gitlab. 本文为我在最初安装配置gitlab服务器的时候留存的笔记 ...