基于jquery實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)控件

字號(hào):


    前臺(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í)有所幫助。