首页 > 语言 > JavaScript > 正文

基于bootstrap3和jquery的分页插件

2024-05-06 16:24:13
字体:
来源:转载
供稿:网友

这篇文章主要介绍了基于bootstrap3和jquery的分页插件的相关资料,需要的朋友可以参考下

自己写的一款基于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. var options = $.extend(defaults, options); 
  39. this.each(function(){ 
  40. options.max=Math.round(options.max); 
  41. options.now=Math.round(options.now); 
  42. if(options.max<=1||isNaN(options.max)||isNaN(options.now))return
  43. options.now=options.now<1?1:options.now>options.max?options.max:options.now; 
  44. var mainbox=$(this).html(""); 
  45. var page_box= $("<ul></ul>").addClass("pagination").appendTo(mainbox); 
  46. if(options.style!=null) page_box.addClass(options.style=="big"?"pagination-lg":options.style=="small"?"pagination-sm":options.style) 
  47. var page_back=$("<li><a href=/"javascript:void(0)/">"+options.first+"</a></li>").appendTo(page_box); 
  48. if(options.now==1) page_back.addClass("disabled"); 
  49. else page_back.on("click",function(){if(typeof options.callback === "function")options.callback(1);}) 
  50. var page_next=$("<li><a href=/"javascript:void(0)/">"+options.last+"</a></li>"); 
  51. if(options.now==options.max) page_next.addClass("disabled"); 
  52. else page_next.on("click",function(){if(typeof options.callback === "function")options.callback(options.max);}) 
  53. var page_now=$("<li><a href=/"javascript:void(0)/">"+options.now+"</a></li>").addClass("active"); 
  54. if(options.max<=10) 
  55. for(var i=1;i<=options.max;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback); 
  56. else 
  57. if(options.now<5){ 
  58. for(var i=1;i<=6;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback); 
  59. $.mypageInsertOther(page_box); 
  60. }else if(options.max-options.now<4){ 
  61. $.mypageInsertOther(page_box); 
  62. for(var i=options.max-5;i<=options.max;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback); 
  63. }else
  64. $.mypageInsertOther(page_box); 
  65. for(var i=options.now-2;i<=options.now+2;i++) $.mypageInsertItem(i,options.now,page_now,page_box,options.callback); 
  66. $.mypageInsertOther(page_box); 
  67. page_next.appendTo(page_box); 
  68. }) 
  69. }, 
  70. $.mypageInsertItem=function(i,now,page_now,page_box,fn){ 
  71. 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); 
  72. else page_now.appendTo(page_box); 
  73. }, 
  74. $.mypageInsertOther=function(page_box){ 
  75. $("<li><a href=/"javascript:void(0)/">…</a></li>").addClass("disabled").appendTo(page_box); 
  76. }, 
  77. $.mypage=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn})}, 
  78. $.mypagesm=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn,style:"pagination-sm"})}, 
  79. $.mypagelg=function(id,now,max,fn){$("#"+id).mypage({now:now,max:max,callback:fn,style:"pagination-lg"})} 
  80. })(jQuery); 

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选