基于jquery實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)控件
前臺(tái)分頁(yè)控件有很多,這里分享我的分頁(yè)控件 pagination.js 1.0版本,該控件基于jquery。
先來看一下預(yù)覽效果:
默認(rèn)情況下,點(diǎn)擊頁(yè)碼會(huì)像博客園一樣,在url后面加上"#p頁(yè)碼"。
控件有2個(gè)參數(shù)需要注意:
1. beforeRender: 在每個(gè)頁(yè)碼項(xiàng)呈現(xiàn)前會(huì)被調(diào)用,參數(shù)為頁(yè)碼的jQuery對(duì)象。這個(gè)時(shí)候我們可以在呈現(xiàn)前做一些處理,例如增加自己的屬性等。默認(rèn)情況下,點(diǎn)擊頁(yè)碼,會(huì)在url后面加上“#p頁(yè)碼”,這樣的url并不會(huì)刷新頁(yè)面。如果我們需要刷新頁(yè)面,例如url為,"default.aspx?index=頁(yè)碼",就可以在這個(gè)回調(diào)函數(shù)里處理。
2. callback: 點(diǎn)擊頁(yè)碼觸發(fā),參數(shù)為整個(gè)options。點(diǎn)擊頁(yè)碼并不會(huì)發(fā)起ajax請(qǐng)求,需要自己處理,options.index 就是本次點(diǎn)擊的頁(yè)碼。有時(shí)候我們的總數(shù)可能會(huì)變化,callback 可以將 options 參數(shù)回傳,這里只要重新設(shè)置總數(shù),然后 return 即可。
具體看調(diào)用例子就明白了。
源代碼:
/*分頁(yè)控件v1.0 date:2015.08.26 */ (function(window,$){ $.fn.pagination = function(options){ var _dftOpts = { count:0,//總數(shù) size:10,//每頁(yè)數(shù)量 index:1,//當(dāng)前頁(yè) lrCount:5,//當(dāng)前頁(yè)左右最多顯示的數(shù)量 lCount:0,//最開始預(yù)留的數(shù)量 rCount:0,//最后預(yù)留的數(shù)量 first:"首頁(yè)", last:"尾頁(yè)", before:"上一頁(yè)", next:"下一頁(yè)", callback:null,//點(diǎn)擊事件 beforeRender:null//項(xiàng)呈現(xiàn)前 }; $.extend(_dftOpts,options); var count = _dftOpts.count; if(count <= 0) return; var _ellipsis = "..."; var _size = _dftOpts.size > 0 ? (_dftOpts.size > count ? count : _dftOpts.size) : 1; var _page = Math.ceil(count / _size); var _index = _dftOpts.index > 0 ? (_dftOpts.index > _page ? _page : _dftOpts.index) : 1; var _lrcount = _dftOpts.lrCount * 2 + 1 > _page ? parseInt((_page - 1) / 2) : _dftOpts.lrCount; var _continueCount = _lrcount * 2 + 1; var _lCount = _dftOpts.lCount <= 0 ? 0 : (_dftOpts.lCount > _page ? _page - 1 : _dftOpts.lCount); var _rCount = _dftOpts.rCount <= 0 ? 0 : (_dftOpts.rCount > _page ? _page - 1 : _dftOpts.rCount); var _first = _dftOpts.first; var _before = _dftOpts.before; var _last = _dftOpts.last; var _next = _dftOpts.next; var _FromTo; var _url = location.pathname + location.search + "#p"; var jthis = this; var jPager = $("<div>",{"class":"pager"}); initJPager(); jthis.append(jPager); regisiterEvent(); return jthis; /*function*/ function initJPager(){ _FromTo = GetFromTo(); var from = _FromTo.from; var to = _FromTo.to; var before = _index <= 1 ? 1 : _index - 1; var next = _index >= _page ? _page : _index + 1; var beforeLast = _page - 1; var jPrevs,jNexts; var i; //前 if(from === 2 && _lCount > 0){ appendLink(1); }else if(from > _lCount + 1){ for(i = 0;i < _lCount;i++){ appendLink(i + 1); } if(_lCount > 0){ appendEllipsis(); } }else{ for(i = 1;i < from;i++){ appendLink(i); } } //連續(xù)部分 for(i = from;i <= to;i++){ if(i === _index){ appendLink(i,true); }else{ appendLink(i); } } //后 if(to === beforeLast && _rCount > 0){ appendLink(_page); }else if(to < _page - _rCount){ if(_rCount > 0){ appendEllipsis(); } for(i = _page - _rCount;i < _page;i++){ appendLink(i + 1); } }else{ for(i = to;i < _page;i++){ appendLink(i + 1); } } appendFirstAndLast(); } function GetFromTo(){ var from,to; from = _index - _lrcount; if(from <= 1){ return {from:1,to:_continueCount}; } if(_page - _index < _lrcount){ from = _page - _continueCount + 1; return {from:from,to:_page}; } to = _index + _lrcount; to = to > _page ? _page : to; return {from:from,to:to}; } function appendLink(index,active){ var jA = $("<a>",{text:index,href:_url+index}); if(active){ jA.addClass("active"); } if(_dftOpts.beforeRender){ _dftOpts.beforeRender(jA); } jPager.append(jA); } function appendFirstAndLast(){ var jFirst = $("<a>",{text:_first}); var jBefore = $("<a>",{text:_before}); var jLast = $("<a>",{text:_last}); var jNext = $("<a>",{text:_next}); jPager.append(jNext).append(jLast); jBefore.insertBefore(jPager.find("a").first()); jFirst.insertBefore(jBefore); if(_index === 1){ jFirst.addClass("disabled"); jBefore.addClass("disabled"); }else{ jFirst.attr("href",_url+1); jBefore.attr("href",_url+(_index-1)); } if(_index === _page){ jLast.addClass("disabled"); jNext.addClass("disabled"); }else{ jLast.attr("href",_url+_page); jNext.attr("href",_url+(_index+1)); } } function appendEllipsis(){ jPager.append(_ellipsis); } //event function regisiterEvent(){ jPager.on("mouseenter","a",function(){ var jthis = $(this); if(!jthis.hasClass("active") && !jthis.hasClass("disabled")){ jthis.addClass("hover"); } }).on("mouseout","a",function(){ var jthis = $(this); if(!jthis.hasClass("active")){ jthis.removeClass("hover"); } }).on("click","a",function(){ var jItem = $(this); if(jItem.hasClass("disabled")){ return; } var text = jItem.text(); var index = 0; switch(text){ case _first: index = 1; break; case _before: index = _index - 1; break; case _last: index = _page; break; case _next: index = _index + 1; break; default: index = parseInt(text); break; } var callback = _dftOpts.callback; var newOpts; _dftOpts.index = index; jPager.remove(); if(callback){ newOpts = callback(_dftOpts); } if(newOpts){ _dftOpts = newOpts; } jthis.pagination(_dftOpts); }); } } })(window,$);
樣式:
樣式很簡(jiǎn)單,可以自己調(diào)。
.pager{height:30px;line-height:30px;font-size: 12px;margin: 25px 0px;text-align: center;color: #2E6AB1;overflow: hidden;} .pager a{border:1px solid #9AAFE5;color:#2E6AB1;margin:0px 5px;padding:5px 8px;text-decoration: none;} .pager a.hover,.pager a.active{background-color:#2E6AB1;border-color:#000080;color:#FFF;} .pager a.disabled{color:#C8CDD2;cursor:auto;}
使用例子:
$(".div1").pagination({ count:200, size:10, index:1, lrCount:3, lCount:1, rCount:1, callback:function(options){ //alert(options.index); //options.count = 300; //return options; }, beforeRender:function(jA){ //jA.attr("href","default.aspx?index="+jA.text()); } });
pagination.js 1.0 還有可能還有一些不足和bug,我會(huì)及時(shí)修正。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- laypage分頁(yè)控件使用實(shí)例詳解
- 基于jQuery的實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)控件
- ASPNETPAGER分頁(yè)控件的使用方法[圖文]
- asp.net分頁(yè)控件AspNetPager的樣式美化
- AspNetPager分頁(yè)控件源代碼(Version 4.2)
- AspNetAjaxPager,Asp.Net通用無刷新Ajax分頁(yè)控件,支持多樣式多數(shù)據(jù)綁定
- asp.net下Repeater使用 AspNetPager分頁(yè)控件
- ASP.Net 分頁(yè)控件源碼
- AspNetPager分頁(yè)控件UrlRewritePattern參數(shù)設(shè)置的重寫代碼
- 學(xué)習(xí)制作MVC4分頁(yè)控件(下)
相關(guān)文章
讓網(wǎng)頁(yè)跳轉(zhuǎn)到指定位置的jquery代碼非書簽
網(wǎng)頁(yè)跳轉(zhuǎn)到指定位置,實(shí)現(xiàn)的方法有很多,本文采用最為簡(jiǎn)單的一種,喜歡朋友可以學(xué)習(xí)下2013-09-09jQuery控制元素顯示、隱藏、切換、滑動(dòng)的方法總結(jié)
這篇文章主要介紹了jQuery控制元素顯示、隱藏、切換、滑動(dòng)的方法總結(jié),本文講解了hide()、show() 、slideDown、slideUp、 slideToggle、fadeIn()、fadeOut()、fadeTo()等方法使用實(shí)例,需要的朋友可以參考下2015-04-04jQuery實(shí)現(xiàn)動(dòng)態(tài)顯示select下拉列表數(shù)據(jù)的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)顯示select下拉列表數(shù)據(jù)的方法,涉及jQuery針對(duì)json數(shù)據(jù)的讀取、遍歷及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-02-02用jquery修復(fù)在iframe下的頁(yè)面錨點(diǎn)失效問題
iframe頁(yè)面沒有滾動(dòng)條,在父窗體中出現(xiàn)滾動(dòng)條,錨點(diǎn)標(biāo)記就會(huì)失效,用js判斷頁(yè)面是否被嵌套,用js計(jì)算iframe在父窗體位置2014-08-08JQuery限制復(fù)選框checkbox可選中個(gè)數(shù)的方法
這篇文章主要介紹了JQuery限制復(fù)選框checkbox可選中個(gè)數(shù)的方法,涉及jQuery操作復(fù)選框長(zhǎng)度判斷與屬性修改的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04jQuery插件ImgAreaSelect實(shí)現(xiàn)頭像上傳預(yù)覽和裁剪功能實(shí)例講解一
這篇文章主要介紹了jQuery插件ImgAreaSelect實(shí)現(xiàn)頭像上傳預(yù)覽和裁剪功能實(shí)例講解一,需要的朋友可以參考下2017-05-05jQuery的實(shí)現(xiàn)原理的模擬代碼 -5 Ajax
對(duì)于 xhr 對(duì)象來說,我們主要通過異步方式訪問服務(wù)器,在 onreadystatechange 事件中處理服務(wù)器回應(yīng)的內(nèi)容。簡(jiǎn)單的 xhr 使用如下所示。2010-08-08基于jquery的兼容各種瀏覽器的iframe自適應(yīng)高度的腳本
在網(wǎng)上找了很多的iframe自適應(yīng)高度的腳本,對(duì)瀏覽的的兼容性都不好。所以就想利用jquery強(qiáng)大的兼容性,寫一個(gè)iframe自適應(yīng)高度的腳本。2010-08-08