jQuery pager.js 插件動態(tài)分頁功能實例分析
本文實例講述了jQuery pager.js 插件動態(tài)分頁功能。分享給大家供大家參考,具體如下:
pager.js 代碼
function Page(opt){
var set = $.extend({num:null,startnum:1,elem:null,callback:null},opt||{});
if(set.startnum>set.num||set.startnum<1){
set.startnum = 1;
}
var n = 0,htm = '';
var clickpages = {
elem:set.elem,
num:set.num,
callback:set.callback,
init:function(){
this.elem.next('div.pageJump').children('.button').unbind('click')
this.JumpPages();
this.elem.children('li').click(function () {
var txt = $(this).children('a').text();
var page = '', ele = null;
var page1 = parseInt(clickpages.elem.children('li.active').attr('page'));
if (isNaN(parseInt(txt))) {
switch (txt) {
case '下一頁':
if (page1 == clickpages.num) {
return;
}
if (page1 >= (clickpages.num - 2) || clickpages.num <= 6 || page1 < 3) {
ele = clickpages.elem.children('li.active').next();
} else {
clickpages.newPages('next', page1 + 1);
ele = clickpages.elem.children('li.active');
}
break;
case '上一頁':
if (page1 == '1') {
return;
}
if (page1 >= (clickpages.num - 1) || page1 <= 3 || clickpages.num <= 6) {
ele = clickpages.elem.children('li.active').prev();
} else {
clickpages.newPages('prev', page1 - 1);
ele = clickpages.elem.children('li.active');
}
break;
case '首頁':
if (page1 == '1') {
return;
}
if (clickpages.num > 6) {
clickpages.newPages('首頁', 1);
}
ele = clickpages.elem.children('li[page=1]');
break;
case '尾頁':
if (page1 == clickpages.num) {
return;
}
if (clickpages.num > 6) {
clickpages.newPages('尾頁', clickpages.num);
}
ele = clickpages.elem.children('li[page=' + clickpages.num + ']');
break;
case '...':
return;
}
} else {
// if ((parseInt(txt) >= (clickpages.num - 3) || parseInt(txt) <= 3) && clickpages.num > 6) {
// clickpages.newPages('jump', parseInt(txt));
// }
// ele = $(this);
// }
// page = clickpages.actPages(ele);
// if (page != '' && page != page1) {
// if (clickpages.callback){
// clickpages.callback(parseInt(page));
// }
var i = parseInt(txt);
if(isNaN(i)||(i<=0)||i>clickpages.num){
return;
}else if(clickpages.num>6){
clickpages.newPages('jump',i);
}else{
var ele = clickpages.elem.children('li[page='+i+']');
clickpages.actPages(ele);
if (clickpages.callback){
clickpages.callback(i);
}
return;
}
if (clickpages.callback){
clickpages.callback(i);
}
}
});
},
//active
actPages:function (ele) {
ele.addClass('active').siblings().removeClass('active');
return clickpages.elem.children('li.active').text();
},
JumpPages:function () {
this.elem.next('div.pageJump').children('.button').click(function(){
var i = parseInt($(this).siblings('input').val());
if(isNaN(i)||(i<=0)||i>clickpages.num){
return;
}else if(clickpages.num>6){
clickpages.newPages('jump',i);
}else{
var ele = clickpages.elem.children('li[page='+i+']');
clickpages.actPages(ele);
if (clickpages.callback){
clickpages.callback(i);
}
return;
}
if (clickpages.callback){
clickpages.callback(i);
}
})
},
//newpages
newPages:function (type, i) {
var html = "",htmlLeft="",htmlRight="",htmlC="";
var HL = '<li><a>...</a></li>';
html = '<li class="topEnd"><a aria-label="Previous">首頁</a></li>'
for (var n = 0;n<5;n++){
htmlC += '<li '+((n-1)==0?'class="active"':'')+' page="'+(i+n-1)+'"><a>'+(i+n-1)+'</a></li>';
htmlLeft += '<li '+((n+2)==i?'class="active"':'')+' page="'+(n+2)+'"><a>'+(n+2)+'</a></li>';
htmlRight += '<li '+((set.num+n-5)==i?'class="active"':'')+' page="'+(set.num+n-5)+'"><a>'+(set.num+n-5)+'</a></li>';
}
switch (type) {
case "next":
if(i<=4){
html+='<li page="1"><a>1</a></li>'+htmlLeft+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}else if(i>=(set.num-3)){
html+='<li page="1"><a>1</a></li>'+HL+htmlRight+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}else{
html += '<li page="1"><a>1</a></li>'+HL+htmlC+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}
break;
case "prev":
if(i<=4){
html+='<li page="1"><a>1</a></li>'+htmlLeft+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}else if(i>=(set.num-3)){
html+='<li page="1"><a>1</a></li>'+HL+htmlRight+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}else{
html += '<li page="1"><a>1</a></li>'+HL+htmlC+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}
break;
case "首頁" :
html+='<li class="active" page="1"><a>1</a></li>'+htmlLeft+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
break;
case "尾頁" :
html+='<li page="1"><a>1</a></li>'+HL+htmlRight+'<li class="active" page="'+set.num+'"><a>'+set.num+'</a></li>';
break;
case "jump" :
if(i<=4){
if(i==1){
html+='<li class="active" page="1"><a>1</a></li>'+htmlLeft+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}else{
html+='<li page="1"><a>1</a></li>'+htmlLeft+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}
}else if((i>=set.num-3)&&(set.num>=7)){
if(i==set.num){
html+='<li page="1"><a>1</a></li>'+HL+htmlRight+'<li class="active" page="'+set.num+'"><a>'+set.num+'</a></li>';
}else{
html+='<li page="1"><a>1</a></li>'+HL+htmlRight+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}
}else{
html += '<li page="1"><a>1</a></li>'+HL+htmlC+HL+'<li page="'+set.num+'"><a>'+set.num+'</a></li>';
}
}
html += '<li class="topEnd"><a aria-label="Next">尾頁</a></li>';
if (this.num > 5 || this.num < 3) {
set.elem.html(html);
clickpages.init({num:set.num,elem:set.elem,callback:set.callback});
}
}
}
if(set.num<=1){
$(".pagination").html('');
return;
}else if(parseInt(set.num)<=6){
n = parseInt(set.num);
var html='<li class="topEnd"><a aria-label="Previous">首頁</a></li>';
for(var i=1;i<=n;i++){
if(i==set.startnum){
html+='<li class="active" page="'+i+'"><a>'+i+'</a></li>';
}else{
html+='<li page="'+i+'"><a>'+i+'</a></li>';
}
}
html +='<li class="topEnd"><a aria-label="Next">尾頁</a></li>';
set.elem.html(html);
clickpages.init();
}else{
clickpages.newPages("jump",set.startnum)
}
}
上面是 pager.js部分
html部分
<script type="text/javascript" charset="utf-8" src="/template/js/jquery-1.9.1.min.js"></script>
<script type="text/javascript" charset="utf-8" src="/template/js/pager.js"></script>
</head>
<div class="dataListPag">
<ul class="pagination" id="page1">
</ul>
<div class="pageJump">
<span>前往</span>
<input type="text"/>
<span>頁</span>
<button type="button" class="button">GO</button>
</div>
</div>
<script>
Page({
num:{$page_mum}, //頁碼數(shù)
startnum:{$page}, //當前頁面有列表切換,在列表切換的時候修改數(shù)字,跳轉(zhuǎn)到當前頁
elem:$('#page1'), //指定的元素
callback:function(n){ //回調(diào)函數(shù)
// 在這里請求當前跳轉(zhuǎn)需要用到的數(shù)據(jù)
// alert('跳轉(zhuǎn)到第'+n+'頁,請求此頁數(shù)據(jù),此頁有列表切換');
window.location.href='id=xigua_re:system_msg&op=private_msglist&page='+n;
}
});
// 數(shù)據(jù)列表的循環(huán)獲取
$('.userArticleType li').on('click',function () {
$('.userArticleType li').removeClass('choose');
$(this).addClass('choose')
})
</script>
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery擴展技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery切換特效與技巧總結(jié)》、《jQuery遍歷算法與技巧總結(jié)》、《jQuery常見經(jīng)典特效匯總》、《jQuery動畫與特效用法總結(jié)》及《jquery選擇器用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計有所幫助。
相關(guān)文章
使用jQuery插件創(chuàng)建常規(guī)模態(tài)窗口登陸效果
隱藏模態(tài)窗口技術(shù)是一種很好的解決方案,用于處理不是特有必要出現(xiàn)在網(wǎng)頁上的界面元素,下面與大家分享下如何利用jQuery插件leanModal建立一個常規(guī)模態(tài)窗口2013-08-08
jQuery解析與處理服務器端返回xml格式數(shù)據(jù)的方法詳解
這篇文章主要介紹了jQuery解析與處理服務器端返回xml格式數(shù)據(jù)的方法,結(jié)合實例形式分析了jQuery基于ajax的get方法與后臺交互操作xml格式數(shù)據(jù)的相關(guān)技巧與注意事項,需要的朋友可以參考下2016-07-07
Jquery多選下拉列表插件jquery multiselect功能介紹及使用
支持點擊label實現(xiàn)checkbox組選擇,頭部選項,如全選/ 取消全選 /關(guān)閉功能,支持鍵盤選擇等等,下面與大家分享下具體使用2013-05-05
jquery中的$(document).ready()與window.onload的區(qū)別
瀏覽器執(zhí)行window.onload函數(shù)不僅僅是在構(gòu)建完DOM樹之后, 也是在所有圖像和其他外部資源完整的加載并且在瀏覽器窗口顯示完畢之后.2009-11-11
jQuery插件FusionCharts實現(xiàn)的MSBar3D圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件FusionCharts實現(xiàn)的MSBar3D圖效果,結(jié)合完整實例形式分析了jQuery使用FusionCharts載入xml數(shù)據(jù)繪制MSBar3D圖的相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03

