对之前写的jquery分页做下升级


Posted in Javascript onJune 19, 2014

以前写的分页用了好久了,但是分页时除了传页面外有时还要传一些其它参数,以前操作时要把传的参数放到隐藏hidden中,分页时在取出来,这样比较麻烦,今天无事,重新包装了一下

直接上代码吧

css用了bootstrap中分页的样式

.pagination-lg > li:first-child > a,
.pagination-lg > li:first-child > span {
border-bottom-left-radius: 6px;
border-top-left-radius: 6px;
}

.pagination-lg > li:last-child > a,
.pagination-lg > li:last-child > span {
border-top-right-radius: 6px;
border-bottom-right-radius: 6px;
}

.pagination-sm > li > a,
.pagination-sm > li > span {
padding: 5px 10px;
font-size: 12px;
}

.pagination-sm > li:first-child > a,
.pagination-sm > li:first-child > span {
border-bottom-left-radius: 3px;
border-top-left-radius: 3px;
}

.pagination-sm > li:last-child > a,
.pagination-sm > li:last-child > span {
border-top-right-radius: 3px;
border-bottom-right-radius: 3px;
}

.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
border: 0;
}

分页代码:

(function ($) {
var PageFunc = function PageFunc() { }
$.PageFunc = function (Total, PageSize, curPageNum, FunUrl,paramStr) {
if (PageSize == "" || PageSize == null || PageSize == undefined) {
PageSize = 10;
}
if (curPageNum == "" || curPageNum == null || curPageNum == undefined) {
curPageNum = 1;
}
var hasParam=true;
if (paramStr == "" || paramStr == null || paramStr == undefined) {
hasParam = false;
}
//计算总页数
Total = parseInt(Total); //总记录数
PageSize = parseInt(PageSize); //每页显示数
curPageNum = parseInt(curPageNum); //当前页
//总页数
var AllPage = Math.floor(Total / PageSize);
if (Total % PageSize != 0) {
AllPage++;
}

var navHtml = "<ul style='margin:0 0 0 0;' class='pagination'>";

if (curPageNum <= 0)
curPageNum = 1;
if (AllPage > 1) {
if (curPageNum != 1) {
//处理首页连接 
var home=1;
if(hasParam)
{
home=home+","+paramStr;
}
navHtml += "<li><a href='javascript:" + FunUrl + "("+home+")' >|<</a></li>";
}
if (curPageNum > 1) {
var previous=parseInt(parseInt(curPageNum) - 1);
if(hasParam)
{
previous=previous+","+paramStr;
}
//处理上一页的连接 
navHtml += "<li><a href='javascript:"+FunUrl+"("+previous+")' ><<</a></li>";
}
else {
navHtml += "<li class='disabled'><a><<</a></li>";
}

var currint = 5;
for (var i = 0; i <= 10; i++) {
//一共最多显示10个页码,前面5个,后面5个 
if ((curPageNum + i - currint) >= 1 && (curPageNum + i - currint) <= AllPage)
if (currint == i) {
//当前页处理 
navHtml += "<li class='active'><a>" + curPageNum + "<span class='sr-only'>(current)</span></a></li>";
}
else {
//一般页处理 
var n = parseInt(parseInt(curPageNum) + parseInt(i) - parseInt(currint));
var nstr=n;
if(hasParam)
{
nstr=nstr+","+paramStr;
}
navHtml += "<li><a href='javascript:" + FunUrl + "("+nstr+")'>" + n + "</a></li>";
}
}
if (curPageNum < AllPage) {
//处理下一页的链接 
var next=parseInt(parseInt(curPageNum) + 1);
if(hasParam)
{
next=next+","+paramStr;
}
navHtml += "<li><a href='javascript:" + FunUrl + "("+next+")'>>></a></li>";
}
else {
navHtml += "<li class='disabled'><a>>></a></li>";
}

if (curPageNum != AllPage) {
var last=parseInt(AllPage);
if(hasParam)
{
last=last+","+paramStr;
}
navHtml += "<li><a href='javascript:" + FunUrl + "("+last+")' >>|</a></li>";
}

}
if(parseInt(AllPage)!=0)
{
navHtml += "<li><a>" + curPageNum + "/" + AllPage + "</a></li>  ";
}
navHtml+="</ul>";
return navHtml;
};

})(jQuery);

调用方法:

注意:第一参数一定要是当前页的值啊

function aa(curpage,param1,param2){
if (curpage == "" || curpage == null || curpage == undefined) {
curpage = 1;
}
var pagesize = 5;
var paramStr="";
paramStr=param1+","+param2+";
$.post("/appdefult/apporder",{"categoryId":param1,"name":param2,"curpage":curpage,"pagesize":pagesize},function(mydata){ 
var pageHtml= $.PageFunc(mydata.total, pagesize, curpage, "aa",paramStr);
$(".page").html(pageHtml);
},"json");
}
Javascript 相关文章推荐
chrome调试javascript详解
Oct 21 Javascript
JavaScript为事件句柄绑定监听函数实例详解
Dec 15 Javascript
AngularJS基础 ng-switch 指令简单示例
Aug 03 Javascript
Js操作DOM元素及获取浏览器高宽的简单方法
Sep 08 Javascript
JS实现DIV高度自适应窗口示例
Feb 16 Javascript
微信小程序页面间通信的5种方式
Mar 31 Javascript
react-navigation 如何判断用户是否登录跳转到登录页的方法
Dec 01 Javascript
基于jQuery实现Ajax验证用户名是否可用实例
Mar 25 jQuery
vue引入js数字小键盘的实现代码
May 14 Javascript
JavaScript设计模式之单例模式简单实例教程
Jul 02 Javascript
大转盘抽奖小程序版 转盘抽奖网页版
Apr 16 Javascript
解析原来浏览器原生支持JS Base64编码解码
Aug 12 Javascript
图片放大镜jquery.jqzoom.js使用实例附放大镜图标
Jun 19 #Javascript
jQuery常用操作方法及常用函数总结
Jun 19 #Javascript
javascript使用正则控制input输入框允许输入的值方法大全
Jun 19 #Javascript
java和javascript获取word文档的书签位置对比
Jun 19 #Javascript
js调试系列 断点与动态调试[基础篇]
Jun 18 #Javascript
jquery+css3打造一款ajax分页插件(自写)
Jun 18 #Javascript
在JavaScript中判断整型的N种方法示例介绍
Jun 18 #Javascript
You might like
php验证码的制作思路和实现方法
2015/11/12 PHP
CodeIgniter读写分离实现方法详解
2016/01/20 PHP
php mysqli查询语句返回值类型实例分析
2016/06/29 PHP
laravel解决迁移文件一次删除创建字段报错的问题
2019/10/24 PHP
用Javascript 获取页面元素的位置的代码
2009/09/25 Javascript
Tips 带三角可关闭的文字提示
2010/10/06 Javascript
High Performance JavaScript(高性能JavaScript)读书笔记分析
2011/05/05 Javascript
关于ExtJS4.1:快捷键支持的问题
2013/04/24 Javascript
chrome下img加载对height()的影响示例探讨
2014/05/26 Javascript
Scala解析Json字符串的实例详解
2017/10/11 Javascript
详解vue数组遍历方法forEach和map的原理解析和实际应用
2018/11/15 Javascript
TypeScript开发Node.js程序的方法
2019/04/30 Javascript
浅谈如何优雅处理JavaScript异步错误
2019/11/12 Javascript
Vue中fragment.js使用方法小结
2020/02/17 Javascript
详解webpack的clean-webpack-plugin插件报错
2020/10/16 Javascript
Python中的FTP通信模块ftplib的用法整理
2016/07/08 Python
python递归查询菜单并转换成json实例
2017/03/27 Python
python实现批量修改图片格式和尺寸
2018/06/07 Python
在pycharm中python切换解释器失败的解决方法
2018/10/29 Python
在Python中居然可以定义两个同名通参数的函数
2019/01/31 Python
python urllib爬虫模块使用解析
2019/09/05 Python
python opencv如何实现图片绘制
2020/01/19 Python
Python爬取新型冠状病毒“谣言”新闻进行数据分析
2020/02/16 Python
浅析matlab中imadjust函数
2020/02/27 Python
美国领先的汽车轮胎和轮毂供应商:TireBuyer
2016/07/21 全球购物
奥地利顶级内衣丝袜品牌英国站:Wolford英国
2016/08/29 全球购物
英国领先的男士服装和时尚零售商:Burton
2017/01/09 全球购物
工程造价与管理专业应届生求职信
2013/11/23 职场文书
工程招投标邀请书
2014/01/26 职场文书
法人委托书的范本格式
2014/09/11 职场文书
医德考评自我评价
2014/09/14 职场文书
考生诚信考试承诺书
2015/04/29 职场文书
2015年小学英语教师工作总结
2015/05/12 职场文书
2016年员工政治思想表现评语
2015/12/02 职场文书
2016年七夕爱情寄语
2015/12/04 职场文书
Windows11里微软已经将驱动程序安装位置A盘删除
2021/11/21 数码科技