对之前写的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 相关文章推荐
Prototype中dom对象方法汇总
Sep 17 Javascript
jQuery ui插件的使用方法代码实例
May 08 Javascript
jquery获取css中的选择器(实例讲解)
Dec 02 Javascript
JavaScript使用Prototype实现面向对象的方法
Apr 14 Javascript
jQuery增加、删除及修改select option的方法
Aug 19 Javascript
Angular.js实现多个checkbox只能选择一个的方法示例
Feb 24 Javascript
js常用的继承--组合式继承
Mar 06 Javascript
微信小程序网络请求的封装与填坑之路
Apr 01 Javascript
JS中的事件委托实例浅析
Mar 22 Javascript
CSS3 动画卡顿性能优化的完美解决方案
Sep 20 Javascript
vue动画效果实现方法示例
Mar 18 Javascript
layui table 表格模板按钮的实例代码
Sep 21 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
Laravel框架学习笔记(二)项目实战之模型(Models)
2014/10/15 PHP
PHP Try-catch 语句使用技巧
2016/02/28 PHP
jQuery Flash/MP3/Video多媒体插件
2010/01/18 Javascript
javascript中处理时间戳为日期格式的方法
2014/01/02 Javascript
jQuery中$(function() {});问题详解
2015/08/10 Javascript
一个简易的js图片轮播效果
2017/07/22 Javascript
Vue实现导出excel表格功能
2018/03/30 Javascript
vue-cli扩展多模块打包的示例代码
2018/04/09 Javascript
Vue写一个简单的倒计时按钮功能
2018/04/20 Javascript
JavaScript引用类型Date常见用法实例分析
2018/08/08 Javascript
vue中各选项及钩子函数执行顺序详解
2018/08/25 Javascript
vue项目前端错误收集之sentry教程详解
2019/05/27 Javascript
react-native聊天室|RN版聊天App仿微信实例|RN仿微信界面
2019/11/12 Javascript
vue实现element表格里表头信息提示功能(推荐)
2019/11/20 Javascript
js实现浏览器打印功能的示例代码
2020/07/15 Javascript
vue 判断两个时间插件结束时间必选大于开始时间的代码
2020/11/04 Javascript
微信小程序实现可拖动悬浮图标(包括按钮角标的实现)
2020/12/29 Javascript
Python模块学习 filecmp 文件比较
2012/08/27 Python
利用soaplib搭建webservice详细步骤和实例代码
2013/11/20 Python
Python实现冒泡,插入,选择排序简单实例
2014/08/18 Python
Python中用pycurl监控http响应时间脚本分享
2015/02/02 Python
详解Django模版中加载静态文件配置方法
2019/07/21 Python
Python 保持登录状态进行接口测试的方法示例
2019/08/06 Python
如何在Django中使用聚合的实现示例
2020/03/23 Python
MyHeritage美国:家族史研究和DNA测试的领先服务
2019/05/27 全球购物
Quiksilver荷兰官方网站:冲浪和滑雪板
2019/11/16 全球购物
Fnac西班牙官网:法国文化和电子产品零售商
2021/03/14 全球购物
有abstract方法的类一定要用abstract修饰吗
2016/03/14 面试题
报社实习生自荐信
2014/01/24 职场文书
学校安全生产承诺书
2014/05/23 职场文书
党的群众路线对照检查材料(个人)
2014/09/24 职场文书
2015年简历自我评价范文
2015/03/11 职场文书
小学班主任工作总结2015
2015/04/07 职场文书
python 逐步回归算法
2021/04/06 Python
oracle覆盖导入dmp文件的2种方法
2021/05/21 Oracle
「女孩的钓鱼慢活」全新版权绘公布
2022/03/21 日漫