2016-02-13 4 views
1

Мне удалось наконец найти плагин, который смог выполнить мой проект.JQuery Следующий Предыдущий Pager

Но я понял, что этот плагин имеет только номера страниц, но не имеет следующего и предыдущего, а также «...», чтобы замаскировать несколько номеров страниц, если их много.

Этот плагин был выполнен в 2013 году, и я думаю, что он больше не жив, чтобы попросить поддержки. Я не очень хорошо разбираюсь в Javascript и JQuery, и я не знаю, как правильно его закодировать.

Любые души могут помочь мне с этим?

Ниже код:

$(document).ready(function() { 
    $('.search-res-list').each(function() { 
     var currentPage = 0; 
     var numPerPage = 4; 
     var $grid = $(this); 
     $grid.bind('repaginate', function() { 
      $grid.find('.search-res-row').hide().slice(currentPage * numPerPage, (currentPage + 1) * numPerPage).show(); 
     }); 
     $grid.trigger('repaginate'); 
     var numRows = $grid.find('.search-res-row').length; 
     var numPages = Math.ceil(numRows/numPerPage); 
     var $pager = $('<div class="pager">Page </div>'); 
     for (var page = 0; page < numPages; page++) { 
      $('<span class="page-number"></span>').text(page + 1).bind('click', { 
       newPage: page 
      }, function(event) { 
       currentPage = event.data['newPage']; 
       $grid.trigger('repaginate'); 
       $(this).addClass('active').siblings().removeClass('active'); 
      }).appendTo($pager).addClass('clickable'); 
     } 
     $pager.insertBefore($grid).find('span.page-number:first').addClass('active'); 
    }); 
}); 

Заранее спасибо за помощь!

ответ

0

Вот как вы можете добавить предыдущие и следующие кнопки для вашего пагинацией и заставить их работать:

$('.search-res-list').each(function() { 
     var currentPage = 0; 
     var numPerPage = 4; 
     var $grid = $(this); 
     $grid.bind('repaginate', function() { 
      $grid.find('.search-res-row').hide().slice(currentPage * numPerPage, (currentPage + 1) * numPerPage).show(); 
     }); 
     $grid.trigger('repaginate'); 
     var numRows = $grid.find('.search-res-row').length; 
     var numPages = Math.ceil(numRows/numPerPage); 
     if(numPages < 10){ /* do this if you want to have 01,02 format (till 10 of course) */ 
      numPages = '0'+numPages; 
     }else{ 
      numPages = numPages; 
     } 
     if(numPages == 0){ 
      numPages = '01'; 
     } 
     var $pager = $('<div class="paged_links productNavLinks"><div class="content-area"><span class="pagexofy"></span></div></div>'); 
     var innerWrap = $pager.find('.pagexofy'); 
     for (var page = 0; page < numPages; page++) { 
      $('<span></span>').text(page + 1).bind('click', { 
       newPage: page 
      }, function(event) { 
       currentPage = event.data['newPage']; 
       $grid.trigger('repaginate'); 
       $(this).addClass('active').siblings().removeClass('active'); 
      }).appendTo(innerWrap).addClass('clickable'); 
     } 
     $pager.insertBefore($grid); 
     $pager.clone().insertAfter($grid); /* do this if you want to show pagination both on top and bottom */ 
     $pager.find('span.clickable:first').addClass('active'); 
     jQuery("span.clickable").each(function(){ 
      var currentText = jQuery(this).text(); 
      if(currentText < 10){ 
       var newText = '0'+currentText; 
       jQuery(this).text(newText); 
      } 
     }); 
     var firstNav = jQuery("span.clickable.active").text(); 
     var finalCount = '<span class="prev page-numbers"></span><span class="pageNavigation">PAGE <span class="firstPageNumLink">'+firstNav + '</span>/' + numPages+'</span><span class="next page-numbers"></span>'; 
     jQuery(".productNavLinks .pagexofy").append(finalCount); 

     jQuery(".paged_links.productNavLinks").each(function(){ 
      jQuery(this).find("span[class^='clickable']:first").addClass('firstPagerNav'); 
      jQuery(this).find("span[class^='clickable']:last").addClass('lastPagerNav'); 
     }); 

     jQuery(".paged_links.productNavLinks .next").click(function(){ 
      jQuery(".paged_links.productNavLinks span.clickable.active").next(".paged_links.productNavLinks span[class^='clickable']").click(); 
      var activeNav = jQuery("span.clickable.active").text(); 
      jQuery(".firstPageNumLink").text(activeNav); 
      if(jQuery(".clickable.firstPagerNav").hasClass('active')){ 
       jQuery(".paged_links.productNavLinks .prev").hide(); 
      }else{ 
       jQuery(".paged_links.productNavLinks .prev").show(); 
      } 
      if(jQuery(".clickable.lastPagerNav").hasClass('active')){ 
       jQuery(".paged_links.productNavLinks .next").hide(); 
      }else{ 
       jQuery(".paged_links.productNavLinks .next").show(); 
      } 
     }); 
     jQuery(".paged_links.productNavLinks .prev").click(function(){ 
      jQuery(".paged_links.productNavLinks span.clickable.active").prev(".paged_links.productNavLinks span[class^='clickable']").click(); 
      var activeNav = jQuery("span.clickable.active").text(); 
      jQuery(".firstPageNumLink").text(activeNav); 
      if(jQuery(".clickable.firstPagerNav").hasClass('active')){ 
       jQuery(".paged_links.productNavLinks .prev").hide(); 
      }else{ 
       jQuery(".paged_links.productNavLinks .prev").show(); 
      } 
      if(jQuery(".clickable.lastPagerNav").hasClass('active')){ 
       jQuery(".paged_links.productNavLinks .next").hide(); 
      }else{ 
       jQuery(".paged_links.productNavLinks .next").show(); 
      } 
     }); 

     if(jQuery(".clickable.firstPagerNav").hasClass('active')){ 
      jQuery(".paged_links.productNavLinks .prev").hide(); 
     } 
     if(jQuery(".clickable.lastPagerNav").hasClass('active')){ 
      jQuery(".paged_links.productNavLinks .next").hide(); 
     } 

    });