首页 > 语言 > JavaScript > 正文

JavaScript实现列表分页功能特效

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

最近在做一个小项目,有时需要制作静态页面网站,而一旦涉及到文章的分页,实现起来非常麻烦,自己又刚入门,对js不是很熟悉,所以就拿来练练手。

最近写了一个js分页的方法,尽管已经有现成的可以用,但还是想自己写写,搞搞清楚。最终实现的效果是:上一页、第一页、…(上n个页码)、n个页码、…(下n个页码)、最后一页、下一页。n可以是奇数也可以是偶数,一般都喜欢取奇数,星石调用的时候传入的参数是5。写的时候,主要注意了以下几个地方:

页码等于1时,只显示上一页、第一页、最后一页,且都没有跳转;

页码小于等于2时,不需要中间的n个页码;

页码小于等于n时,显示所有页码,不显示2个“…”;

2个“…”换页时,换n个页码,如果接近最前面或最后面几页了,则显示最前面或最后面n个页码。

下面贴出代码,供大家探讨:

 

 
  1. //总页数,当前页数,跳转地址,第一页和最后一页之间显示的页码数量 
  2. function pageBar(tp,cp,url,pn){ 
  3. var str = ‘<ul class=”page”>'; 
  4. if(tp>1 && cp>1){ 
  5. var prev = cp-1; 
  6. str += ‘<li><a class=”prev” title=”上一页” href=”javascript:goPage(‘+prev+‘,/”+url+‘/');”><span>上一页</span></a></li> ‘; 
  7. }else
  8. str += ‘<li><a class=”prev” title=”上一页” href=”javascript:void(0);”><span>上一页</span></a></li> ‘; 
  9. if(tp>1){ 
  10. //第一页 
  11. if(cp==1){ 
  12. str +=‘<li class=”current”><a href=”javascript:goPage(1,/”+url+‘/');”><span>1</span></a></li> ‘; 
  13. }else
  14. str +=‘<li><a href=”javascript:goPage(1,/”+url+‘/');”><span>1</span></a></li> ‘; 
  15.  
  16. if(tp>2){ 
  17. var pnh = Math.floor(pn/2); 
  18.  
  19. //循环开始页码 
  20. var s = cp-pnh; 
  21. if(s<=1){ 
  22. s = 2; 
  23.  
  24. //循环结束页码 
  25. var e = cp+pnh; 
  26. if(e>=tp){ 
  27. e = tp-1; 
  28.  
  29. if(s<=(1+pnh)){ 
  30. if(tp>(pn+2)){ 
  31. e = s+(pn-1); 
  32. if(e>=tp){ 
  33. e = tp-1; 
  34. }else
  35. s = 2; 
  36.  
  37. if(e>=(tp-pnh)){ 
  38. if(tp>(pn+2)){ 
  39. s = e-(pn-1); 
  40. if(s<=1){ 
  41. s = 2; 
  42. }else
  43. e = tp-1; 
  44.  
  45. if(e<s){ 
  46. e = s; 
  47.  
  48. //第一页后的多页跳转 
  49. if(s>2){ 
  50. var sp = cp-pn; 
  51. if(sp<1){ 
  52. sp=1; 
  53. str += ‘<li><a name=”break” href=”javascript:goPage(‘+sp+‘,/”+url+‘/');”><span>…</span></a></li> ‘; 
  54.  
  55. for(var i=s;i<=e;i++){ 
  56. if(i==cp){ 
  57. str += ‘<li class=”current”><a href=”javascript:goPage(‘+i+‘,/”+url+‘/');”><span>'+i+‘</span></a></li> ‘; 
  58. }else
  59. str += ‘<li><a href=”javascript:goPage(‘+i+‘,/”+url+‘/');”><span>'+i+‘</span></a></li> ‘; 
  60.  
  61. //最后一页前的多页跳转 
  62. if(e < (tp-1)){ 
  63. var ep = cp+pn; 
  64. if(ep>tp){ 
  65. ep=tp; 
  66. str += ‘<li><a name=”break” href=”javascript:goPage(‘+ep+‘,/”+url+‘/');”><span>…</span></a></li> ‘; 
  67.  
  68. //最后一页 
  69. if(cp==tp){ 
  70. str +=‘<li class=”current”><a href=”javascript:goPage(‘+tp+‘,/”+url+‘/');”><span>'+tp+‘</span></a></li> ‘; 
  71. }else
  72. str +=‘<li><a href=”javascript:goPage(‘+tp+‘,/”+url+‘/');”><span>'+tp+‘</span></a></li> ‘; 
  73.  
  74. }else
  75. str +=‘ <li class=”current”><a href=”javascript:void(0);”><span>1</span></a></li> ‘; 
  76.  
  77. if(tp>1 && cp<tp){ 
  78. var next = cp+1; 
  79. str += ‘<li><a class=”next” title=”下一页” href=”javascript:goPage(‘+next+‘,/”+url+‘/');”><span>下一页</span></a></li>'
  80. }else
  81. str += ‘<li><a class=”next” title=”下一页” href=”javascript:void(0);”><span>下一页</span></a></li>'; 
  82. str += ‘</ul>'; 
  83. return str; 
  84.  
  85. //跳转页码,跳转地址 
  86. function goPage(cp,url){ 
  87. window.location.href = url+cp; 

以上所述就是本文的全部内容了,希望大家能够喜欢。

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

图片精选