先来看看效果:

对于前端分页,关键是思路,和分页算法。本想多说两句,可又觉得没什么可说的,看代码吧:

如何使用?

            $("#pging").zPagination({
'navEvent':function(){
console.log('取数据Ajax');
}
});

JS代码

//分页Pagination
; (function ($, window) {
var defaults = {
rowCount: 400, //总数据行数
navPage: 10, //每次显示多少页导航
pageSize: 10, //每页多少条数据
currentPage: 20, //当前是第几页
showRowsCount: true, //是否显示总数据数
showGoto: false, //是否有跳转功能
navUrl: '', //点击页后所跳转到的URL,用于非Ajax()方式:/Home/Index.aspx?pageIndex=
ajaxUrl: '', //点击页后从哪个URL取数据,用于Ajax()方式:/Home/Index
isAjaxData: true, //是从Ajax取数据还是非Ajax取数据
divClass: 'z_paging', //外围DIV的Class,其下有.z_paging a , .z_paging a:hover , .z_paging>.z_paging_current
navEvent: ''//点击导航页后所要执行的事件function(){...},通常和isAjaxData==true联用。
};
$.fn.zPagination = function (options) {
$this = $(this);
var ops = $.extend({}, defaults, options);
var _pageCount = 0;
var _startNav = 0;
var _endNav = 0; //初始化参数
function initParameter() {
_pageCount = (ops.rowCount % ops.pageSize == 0) ? ops.rowCount / ops.pageSize : parseInt(ops.rowCount / ops.pageSize) + 1;
if (ops.currentPage <= parseInt(ops.navPage / 2)) {
_startNav = 1;
} else {
_startNav = ops.currentPage - parseInt(ops.navPage / 2); //(30-(10/2)==25)
} _endNav = _startNav + ops.navPage;
if (_endNav > _pageCount) {
_endNav = _pageCount;
_startNav = _endNav - ops.navPage;
}
if (_startNav < 1) {
_startNav = 1;
} //生成DOM元素
if (ops.isAjaxData == true) {
generateAjaxDom();
} else {
generateDom();
}
}; //网址方式加载数据 isAjaxData==false 时执行
function generateDom() {
$this.html('').addClass(ops.divClass);
$('<a href=' + ops.navUrl + '1></a>').html(1).appendTo($this);
_startNav++;
if (_startNav != 2) {
$('<span></span>').html('...').appendTo($this);
}
while (_startNav < _endNav) {
$('<a href=' + ops.navUrl + _startNav + '></a>').html(_startNav).appendTo($this);
_startNav++;
}
_startNav--; if (_endNav < _pageCount) {
$('<span></span>').html('...').appendTo($this);
}
if (_startNav < _endNav && _endNav <= _pageCount) {
$('<a href=' + ops.navUrl + _endNav + '></a>').html(_pageCount).appendTo($this);
}
findCurrentNum();
} //通过Ajax方式加载数据 isAjaxData==true 时执行
function generateAjaxDom() {
$this.html('').addClass(ops.divClass);
$('<a href="javascript:void(0);"></a>').html(1).appendTo($this);
_startNav++;
if (_startNav != 2) {
$('<span></span>').html('...').appendTo($this);
}
while (_startNav < _endNav) {
$('<a href="javascript:void(0);"></a>').html(_startNav).appendTo($this);
_startNav++;
}
_startNav--; if (_endNav < _pageCount) {
$('<span></span>').html('...').appendTo($this);
}
if (_startNav < _endNav && _endNav <= _pageCount) {
$('<a href="javascript:void(0);"></a>').html(_pageCount).appendTo($this);
} //给每个<a />添加事件
function initAjaxData() {
$this.find('a').bind('click', function () {
try {
ops.currentPage = parseInt($(this).html());
if (typeof (ops.navEvent) == 'function') {
ops.navEvent();
initParameter(); //重新生成页数导航条,放在这里,放在这里,是为了避免因参数没传对,而出现看见导航页变了,而数据没变的情况
}
} catch (e) { }
});
}
initAjaxData();
findCurrentNum();
} //找出当前页
function findCurrentNum() {
$this.find('a').each(function () {
if (parseInt($(this).html()) == ops.currentPage) {
$(this).addClass('z_paging_current');
}
});
appendEle();
} //附加元素 是否显示总数据数
function appendEle() {
if (typeof (ops.showRowsCount) == 'boolean') {
$('<span class="z_rows_count"></span>').html('总数:' + ops.rowCount).appendTo($this);
}
} initParameter(); //获取当前是第几页 调用方式:this.currentPage
this.currentPage = function () {
return ops.currentPage();
}; return this;
};
})(jQuery, window);

CSS

/*zPagination Begin*/
.z_paging
{
}
.z_paging a, .z_paging span
{
float: left;
display: inline-block;
vertical-align: text-bottom;
text-align: center;
line-height: 34px;
background-color: #fff;
}
.z_paging a
{
cursor: pointer;
border-radius: 3px;
border: 1px solid #e5e5e5;
padding: 0 12px;
margin: 0 2px;
text-decoration: none;
color: #734ba9;
}
.z_paging a:hover
{
background-color: #6699ff;
color: #fff;
}
.z_paging > .z_paging_current
{
background-color: #e5e5e5;
}
.z_paging > .z_rows_count
{
border-radius: 3px;
border: 1px solid #e5e5e5;
padding: 0 12px;
margin: 0 2px;
text-decoration: none;
color: #734ba9;
}
/*zPagination End*/

最新文章

  1. EL
  2. 异构SOA系统架构之Asp.net实现(兼容dubbo)
  3. 第一、初识C语言
  4. 蜥蜴(bzoj 1066)
  5. POJ 3416 Crossing --离线+树状数组
  6. 老项目的#iPhone6于iPhone6Plus适配#iPhone6分辨率与适配
  7. 取精华、去糟粕!适合iOS开发者的15大网站推荐
  8. Ubuntu 14.04的SWAP 为0
  9. (转)iOS7界面设计规范(9) - UI基础 - 动画
  10. Anatomy of a Program in Memory
  11. iOS开发之第三方分享QQ分享,史上最新最全第三方分享QQ方式实现
  12. 微信 SDK 不能 分享
  13. 你的flume-ng的第一篇博客
  14. [翻译]成为顶尖程序员应当学什么?Python、C还是Ruby?
  15. 三、vue之router
  16. C#在SharePoint文档库下动态新增文件夹
  17. DataGridView 访问任意行不崩溃
  18. Powershell渗透测试系列–进阶篇
  19. ELK之在windows安装filebeat收集日志
  20. express框架实现承载静态页面的能力

热门文章

  1. Quartz2D简单图形
  2. .18-浅析webpack源码之compile流程-rules参数处理(1)
  3. [转]解决Magento批量导入带图片的商品的问题
  4. SQLServer 里面的 DDL,DML,DCL,TCL
  5. 【MongoDB学习-在.NET中的简单操作】
  6. Oracle TO_DATE() 函数格式化时间【全】
  7. css span宽度和css span高度成功设置经验篇
  8. java中那些类是线程安全的?
  9. 方程整数解-2015省赛C语言A组第一题
  10. 【12】外观模式(Facade Pattern)