jQuery插件实例六:jQuery 前端分页
先来看看效果:

对于前端分页,关键是思路,和分页算法。本想多说两句,可又觉得没什么可说的,看代码吧:
如何使用?
$("#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*/
jQuery插件实例六:jQuery 前端分页的更多相关文章
- jQuery插件实例五:手风琴效果[动画效果可配置版]
昨天写了个jQuery插件实例四:手风琴效果[无动画版]那个是没有动画效果的,且可配置性不高,本篇为有动画效果.对于一些数据做了动态的计算,以实现自适应. 欢迎大家入群相互交流,学习,新群初建,欢迎各 ...
- 【jQuery插件】用jQuery Masonry快速构建一个pinterest网站布局(转)
[jQuery插件]用jQuery Masonry快速构建一个pinterest网站布局 时间:2011年03月21日作者:愚人码头查看次数:29,744 views评论次数:25条评论 前段时间领导 ...
- 转 jquery插件--241个jquery插件—jquery插件大全
241个jquery插件—jquery插件大全 jquery插件jqueryautocompleteajaxjavascriptcoldfusion jQuery由美国人John Resig创建,至今 ...
- 精美jQuery插件及源码 前端开发福利
jQuery是一个非常不错的javascript框架,很多前端开发者喜欢的原因不仅是因为jQuery使用起来方便,更重要的是因为它的插件很多,我们可以将这些插件应用到自己的项目中去.下面这些精美的jQ ...
- 转:精美jQuery插件及源码 前端开发福利
原文来自于:http://www.html5tricks.com/pretty-jquery-plugin.html jQuery是一个非常不错的javascript框架,很多前端开发者喜欢的原因不仅 ...
- 一个很简单的jQuery插件实例教程(菜鸟级)
很多公司的前端设计开发人员都是女孩子,而这些女孩子很多JavaScript技能都不是很好.而前端开发过程中,JavaScript技能又是必不可少的.所以,如果前端小MM正在为某个JavaScript效 ...
- jQuery插件实例一:年华时代插件Alert对话框
在工作中使用jQuery插件相信对于程序员来说非常普遍,在网络上也有很多优秀的插件可供大家使用,功能非常强大.在之前用过的一些插件中,有些太过追求功能的强大和可配置性,造成使用的复杂度上升.个人认为与 ...
- 网站开发常用jQuery插件总结(六)关键词说明插件cluetip
我们开发的网站,总有它一定的用途.如企业站用来宣传企业或展示产品,技术站用来分享自己的思路和经验.既然网站有了它的用途,那么就拥有了它本身的关键词(关键词说明网站的主要内容).例如企业站的关键词大部分 ...
- JQUERY插件学习之jQuery UI
jQuery UI:http://jqueryui.com/ jQuery UI介绍: jQuery UI 是以 jQuery 为基础的开源 JavaScript 网页用户界面代码库.包含底层用户交互 ...
随机推荐
- 了解MySQL联表查询中的驱动表,优化查询,以小表驱动大表
一.为什么要用小表驱动大表 1.驱动表的定义 当进行多表连接查询时, [驱动表] 的定义为: 1)指定了联接条件时,满足查询条件的记录行数少的表为[驱动表] 2)未指定联接条件时,行数少的表为[驱动表 ...
- linux----之tcpdump小用
1.通过抓包大致确定访问量 #time tcpdump -nn -i eth0 'tcp[tcpflags] = tcp-syn' -c 10000 >/dev/null 根据real时间判断访 ...
- Shiro遇到的SecurityManager红色警告
问题如图 需要添加一个导入 import org.apache.shiro.mgt.SecurityManager; 这样就不会报错了
- 【Java基础】5、java中的匿名内部类
匿名内部类也就是没有名字的内部类 正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写 但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口 实例1:使用匿名内部类来实现抽象方 ...
- 撩课-Web大前端每天5道面试题-Day1
1. var的变量提升的底层原理是什么? JS引擎的工作方式是: 1) 先解析代码,获取所有被声明的变量: 2)然后在运行.也就是说分为预处理和执行两个阶段. 变量提升:所有变量的声明语句都会被提升到 ...
- linux mysql 卸载与安装及配置命令
1.RPM包安装方式的MySQL卸载 1) 检查是否安装了MySQL组件. # rpm -qa | grep -i mysql 2)卸载前关闭MySQL服务 # service mysql statu ...
- canvas与svg特性和使用对比
什么是 Canvas? HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像. 画布是一个矩形区域,您可以控制其每一像素. canvas 拥有多种绘制路径.矩形.圆形.字符以 ...
- 【代码笔记】iOS-JQIndicatorViewDemo
一,效果图. 二,工程图. 三,代码. #import "ViewController.h" #import "JQIndicatorView.h" @inte ...
- JS--我发现,原来你是这样的JS(二)(基础概念--躯壳篇--不妨从中文角度看js)
一.介绍 这是红宝书(JavaScript高级程序设计 3版)的读书笔记第二篇(基础概念--躯壳篇),有着部分第三章的知识内容,当然其中还有我个人的理解. 红宝书这本书可以说是难啃的,要看完不容易,挺 ...
- 大数据【六】ZooKeeper部署
这是一个分布式服务框架,阿帕奇的一个子项目.关于ZooKeeper我只简单的部署一下,以便后面的HBase. 一 概述 ZooKeeper 分布式服务框架是 Apache Hadoop 的一个子项目 ...