对之前写的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 相关文章推荐
Cookie 注入是怎样产生的
Apr 08 Javascript
写出更好的JavaScript程序之undefined篇(中)
Nov 23 Javascript
几个比较经典常用的jQuery小技巧
Mar 01 Javascript
jquery设置控件位置的方法
Aug 21 Javascript
jquery和js实现对div的隐藏和显示方法
Sep 26 Javascript
轻松使用jQuery双向select控件Bootstrap Dual Listbox
Dec 13 Javascript
jquery+CSS3实现3D拖拽相册效果
Jul 18 Javascript
Node.js读写文件之批量替换图片的实现方法
Sep 07 Javascript
JS中的phototype详解
Feb 04 Javascript
如何快速上手Vuex
Feb 14 Javascript
让bootstrap的carousel支持滑动滚屏的实现代码
Nov 27 Javascript
layui点击导航栏刷新tab页的示例代码
Aug 14 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&amp;mysql(五)
2006/10/09 PHP
PHP实现伪静态方法汇总
2016/01/13 PHP
php抽象方法和普通方法的区别点总结
2019/10/13 PHP
Aster vs Newbee BO3 第二场2.18
2021/03/10 DOTA
页面中iframe相互传值传参
2009/12/13 Javascript
javascript AOP 实现ajax回调函数使用比较方便
2010/11/20 Javascript
jQuery简单图表peity.js使用示例
2014/05/02 Javascript
node.js中的fs.realpath方法使用说明
2014/12/16 Javascript
学习Angular中作用域需要注意的坑
2016/08/17 Javascript
jQuery Easyui 下拉树组件combotree
2016/12/16 Javascript
Webpack中css-loader和less-loader的使用教程
2017/04/27 Javascript
layer.open 按钮的点击事件关闭方法
2018/08/17 Javascript
Vuejs2 + Webpack框架里,模拟下载的实例讲解
2018/09/05 Javascript
详解JavaScript作用域和作用域链
2019/03/19 Javascript
基于vue实现一个禅道主页拖拽效果
2019/05/27 Javascript
vue路由插件之vue-route
2019/06/13 Javascript
js模拟F11页面全屏显示
2019/09/17 Javascript
[03:55]2014DOTA2国际邀请赛 Fnatic经理采访赢DK在情理之中
2014/07/10 DOTA
[08:08]DOTA2-DPC中国联赛2月28日Recap集锦
2021/03/11 DOTA
Django中使用locals()函数的技巧
2015/07/16 Python
asyncio 的 coroutine对象 与 Future对象使用指南
2016/09/11 Python
pytorch中如何使用DataLoader对数据集进行批处理的方法
2019/08/06 Python
详解python播放音频的三种方法
2019/09/23 Python
Python list运算操作代码实例解析
2020/01/20 Python
pytorch实现seq2seq时对loss进行mask的方式
2020/02/18 Python
ipython jupyter notebook中显示图像和数学公式实例
2020/04/15 Python
Jupyter Notebook安装及使用方法解析
2020/11/12 Python
CSS3实例分享--超炫checkbox复选框和radio单选框
2014/09/01 HTML / CSS
纯CSS3制作页面切换效果的实例代码
2019/05/30 HTML / CSS
全球性的在线鞋类品牌:Public Desire
2019/04/03 全球购物
eBay加拿大站:eBay.ca
2019/06/20 全球购物
家具商场的活动方案
2014/08/16 职场文书
2014最新股权信托合同协议书
2014/11/18 职场文书
2014年学校教学工作总结
2014/12/06 职场文书
Netty结合Protobuf进行编解码的方法
2021/06/26 Java/Android
java.util.NoSuchElementException原因及两种解决方法
2022/06/28 Java/Android