当前位置:Gxlcms > JavaScript > 基于bootstrap3和jquery的分页插件

基于bootstrap3和jquery的分页插件

时间:2021-07-01 10:21:17 帮助过:9人阅读

自己写的一款基于bootstrap3和jquery的分页插件,初学jquery插件写法,写的很一般。拿出来献丑了。

  1. /**
  2. * 基于bootstrap3的jquery分页插件
  3. * 调用方式分两种
  4. * 1.直接调用法
  5. * 普通大小
  6. * $.mypage(id,now,max,fn);
  7. * 大尺寸
  8. * $.mypagelg(id,now,max,fn);
  9. * 小尺寸
  10. * $.mypagesm(id,now,max,fn);
  11. *
  12. * 参数说明:id为放置分页容器的ID,now为当前页,max为最大页,fn为回掉函数,回掉函数有一个参数为点击的页码
  13. *
  14. * 2.选择器调用法
  15. * $(selector).mypage({
  16. * now:now,
  17. * last:last,
  18. * callback:fn,
  19. * max:max,
  20. * first:first,
  21. * style,style
  22. * });
  23. * 参数说明:now为当前页,max为最大页,callback为回掉函数,回掉函数有一个参数为点击的页码,style可选参数,有"big" 和"small",fitst为首页按钮的文本,last为尾页按钮的文本
  24. *
  25. * 当最大页为1时将不显示,当当前页设置小于1时默认为1,当前页大于最大页时默认为最大页
  26. * 引用本js前请先引用jquery的js文件和bootstrap3的css文件
  27. *
  28. */
  29. (function ($) {
  30. $.fn.mypage = function(options){
  31. var defaults = {
  32. now:1,
  33. max:1,
  34. callback:null,
  35. style:null,
  36. first:"«",
  37. last:"»"
  38. }
  39. var options = $.extend(defaults, options);
  40. this.each(function(){
  41. options.max=Math.round(options.max);
  42. options.now=Math.round(options.now);
  43. if(options.max<=1||isNaN(options.max)||isNaN(options.now))return;
  44. options.now=options.now<1?1:options.now>options.max?options.max:options.now;
  45. var mainbox=$(this).html("");
  46. var page_box= $("<ul></ul>").addClass("pagination").appendTo(mainbox);
  47. if(options.style!=null) page_box.addClass(options.style=="big"?"pagination-lg":options.style=="small"?"pagination-sm":options.style)
  48. var page_back=$("<li><a href=\"javascript:void(0)\">"+options.first+"</a></li>").appendTo(page_box);
  49. if(options.now==1) page_back.addClass("disabled");
  50. else page_back.on("click",function(){if(typeof options.callback === "function")options.callback(1);})
  51. var page_next=$("<li><a href=\"javascript:void(0)\">"+options.last+"</a></li>");
  52. if(options.now==options.max) page_next.addClass("disabled");
  53. else page_next.on("click",function(){if(typeof options.callback === "function")options.callback(options.max);})
  54. var page_now=$("<li><a href=\"javascript:void(0)\">"+options.now+"</a></li>").addClass("active");
  55. if(options.max<=10)
  56. for(var i=1;i<=options.max;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback);
  57. else
  58. if(options.now<5){
  59. for(var i=1;i<=6;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback);
  60. $.mypageInsertOther(page_box);
  61. }else if(options.max-options.now<4){
  62. $.mypageInsertOther(page_box);
  63. for(var i=options.max-5;i<=options.max;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback);
  64. }else{
  65. $.mypageInsertOther(page_box);
  66. for(var i=options.now-2;i<=options.now+2;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback);
  67. $.mypageInsertOther(page_box);
  68. }
  69. page_next.appendTo(page_box);
  70. })
  71. },
  72. $.mypageInsertItem=function(i,now,page_now,page_box,fn){
  73. if(i!=now) $("<li><a href=\"javascript:void(0)\">"+i+"</a></li>").on("click",function(){if(typeof fn === "function")fn($(this).text());}).appendTo(page_box);
  74. else page_now.appendTo(page_box);
  75. },
  76. $.mypageInsertOther=function(page_box){
  77. $("<li><a href=\"javascript:void(0)\">…</a></li>").addClass("disabled").appendTo(page_box);
  78. },
  79. $.mypage=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn})},
  80. $.mypagesm=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn,style:"pagination-sm"})},
  81. $.mypagelg=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn,style:"pagination-lg"})}
  82. })(jQuery);

以上所述就是本文的全部内容了,希望对大家学习jQuery能够有所帮助。

人气教程排行