这篇文章主要介绍了pageGroup.js怎么实现分页功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
pageGroup.js实现分页功能的具体代码如下
1.html页面
引入
<link rel="stylesheet" type="text/css" href="/stylesheets/pageGroup.css" >
<script src="/javascripts/web/pageGroup.js" type="text/javascript"></script>
<div id="pageGro" class="cb">
{{if maxPage>0}}//总页数
<div class="pageUp">上一页</div>
<div class="pageList">
<ul>
</ul>
</div>
<div class="pageDown">下一页</div>{{/if}}
<div id="countPage" >{{maxPage}}</div>//总页数
<div id="nowPage" >{{page}}</div>//当前页
<div id="title" >{{title}}</div>//标题
</div>
2.pageGroup.css
/* CSS Document */
/*分页*/
#pageGro{ width:400px; height:25px; margin:0px auto; padding-top:30px;}
#pageGro div,#pageGro div ul li{ font-size:12px; color:#999; line-height:23px; float:left; margin-left:5px;}
#pageGro div ul li{ width:22px; text-align:center; border:1px solid #999; cursor:pointer;}
#pageGro div ul li.on{ color:#fff; background:#3c90d9; border:1px solid #3c90d9;}
#pageGro .pageUp,#pageGro .pageDown{ width:63px; border:1px solid #999; cursor:pointer;}
#pageGro .pageUp{ text-indent:23px; background:url(/images/pageUp.png) 5px 7px no-repeat;}
#pageGro .pageDown{ text-indent:5px; background:url(/images/pageDown.png) 46px 6px no-repeat;}
3.pageGroup.js
// JavaScript Document
$(function(){
//根据总页数判断,如果小于5页,则显示所有页数,如果大于5页,则显示5页。根据当前点击的页数生成
var maxPage=jQuery("#countPage").text();
var nowPage=jQuery("#nowPage").text();
var index=parseInt(nowPage);//当前页
var title=jQuery("#title").text();
var pageCount =parseInt(maxPage) ;//模拟后台总页数
//生成分页按钮
if(pageCount>5){
page_icon(1,5,0);
pageGroup(index,pageCount);
}else{
//alert("66");
page_icon(1,pageCount,0);
pageGroup(index,pageCount);
}
//点击分页按钮触发
$("#pageGro li").live("click",function(){
if(pageCount > 5){
var pageNum = parseInt($(this).html());//获取当前页数
window.location.href = "/article/search/"+title+"/"+pageNum;
pageGroup(pageNum,pageCount);
}else{
var indexpage=jQuery(this).text();
window.location.href = "/article/search/"+title+"/"+indexpage;
$(this).addClass("on");
$(this).siblings("li").removeClass("on");
}
});
//点击上一页触发
$("#pageGro .pageUp").click(function(){
if(pageCount > 5){
if(index>1){
window.location.href = "/article/search/"+title+"/"+(index-1);
}
}else{
if(index > 1){
window.location.href = "/article/search/"+title+"/"+(index-1);
$("#pageGro li").removeClass("on");//清除所有选中
}
}
});
//点击下一页触发
$("#pageGro .pageDown").click(function(){
if(pageCount > 5){
if(nowPage<pageCount){
window.location.href = "/article/search/"+title+"/"+(index+1);
}
}else{
if(index< pageCount){
window.location.href = "/article/search/"+title+"/"+(index+1);
$("#pageGro li").removeClass("on");//清除所有选中
}
}
});
});
//点击跳转页面
function pageGroup(pageNum,pageCount){
if(pageCount>5){
switch(pageNum){
case 1:
page_icon(1,5,0);
break;
case 2:
page_icon(1,5,1);
break;
case pageCount-1:
page_icon(pageCount-4,pageCount,3);
break;
case pageCount:
page_icon(pageCount-4,pageCount,4);
break;
default:
page_icon(pageNum-2,pageNum+2,2);
break;
}
}
if(pageCount<5){
switch(pageNum){
case 1:
page_icon(1,pageCount,0);
break;
case 2:
page_icon(1,pageCount,1);
break;
case pageCount-1:
page_icon(1,pageCount,2);
break;
case pageCount:
page_icon(1,pageCount,3);
break;
}
}
if(pageCount==5){
switch(pageNum){
case 1:
page_icon(1,pageCount,0);
break;
case 2:
page_icon(1,pageCount,1);
break;
case pageCount-1:
page_icon(1,pageCount,3);
break;
case pageCount:
page_icon(1,pageCount,4);
break;
default:
page_icon(1,pageNum+2,2);
break;
}
}
}
//根据当前选中页生成页面点击按钮
function page_icon(page,count,eq){
var ul_html = "";
for(var i=page; i<=count; i++){
ul_html += "<li>"+i+"</li>";
}
$("#pageGro ul").html(ul_html);
$("#pageGro ul li").eq(eq).addClass("on");
}
//上一页
function pageUp(pageNum,pageCount){
switch(pageNum){
case 1:
break;
case 2:
page_icon(1,5,0);
break;
case pageCount-1:
page_icon(pageCount-4,pageCount,2);
break;
case pageCount:
page_icon(pageCount-4,pageCount,3);
break;
default:
page_icon(pageNum-2,pageNum+2,1);
break;
}
}
//下一页
function pageDown(pageNum,pageCount){
switch(pageNum){
case 1:
page_icon(1,5,1);
break;
case 2:
page_icon(1,5,2);
break;
case pageCount-1:
page_icon(pageCount-4,pageCount,4);
break;
case pageCount:
break;
default:
page_icon(pageNum-2,pageNum+2,3);
break;
}
}
感谢你能够认真阅读完这篇文章,希望小编分享的“pageGroup.js怎么实现分页功能”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。