首页 > 语言 > JavaScript > 正文

javascript实现列表滚动的方法

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

这篇文章主要介绍了javascript实现列表滚动的方法,较为详细的分析了javascript实现列表滚动的页面布局及javascript滚动效果的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了javascript实现列表滚动的方法。分享给大家供大家参考。具体如下:

index.html如下:

 

 
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
  2. "http://www.w3.org/TR/html4/loose.dtd"
  3. <html> 
  4. <head> 
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  6. <meta name="keywords" content="" /> 
  7. <meta name="description" content="" /> 
  8. <link rel="stylesheet" type="text/css" href="css/global.css" /> 
  9. <script type="text/javascript" src="js/jquery-1.7.min.js"></script> 
  10. <script type="text/javascript" src="js/scroll_img.js"></script> 
  11. <title>图片列表滚动</title> 
  12. </head> 
  13. <body> 
  14. <div class="scroll_img_wrap clearfix"
  15. <p class="left_btn"><a href="javascript:void(0)"><img src="images/btn.jpg" /></a></p> 
  16. <div id="scroll_img"
  17. <ul class="scroll_img_list clearfix"
  18. <li> 
  19. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  20. <p><a href="#">information1</a></p> 
  21. </li> 
  22. <li> 
  23. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  24. <p><a href="#">information2</a></p> 
  25. </li> 
  26. <li> 
  27. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  28. <p><a href="#">information3</a></p> 
  29. </li> 
  30. <li> 
  31. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  32. <p><a href="#">information4</a></p> 
  33. </li> 
  34. <li> 
  35. <p><a href="#"><img src="images/2.jpg" alt="#" /></a></p> 
  36. <p><a href="#">information5</a></p> 
  37. </li> 
  38. <li> 
  39. <p><a href="#"><img src="images/2.jpg" alt="#" /></a></p> 
  40. <p><a href="#">information6</a></p> 
  41. </li> 
  42. <li> 
  43. <p><a href="#"><img src="images/2.jpg" alt="#" /></a></p> 
  44. <p><a href="#">information7</a></p> 
  45. </li> 
  46. <li> 
  47. <p><a href="#"><img src="images/2.jpg" alt="#" /></a></p> 
  48. <p><a href="#">information8</a></p> 
  49. </li> 
  50. <li> 
  51. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  52. <p><a href="#">information9</a></p> 
  53. </li> 
  54. <li> 
  55. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  56. <p><a href="#">information10</a></p> 
  57. </li> 
  58. <li> 
  59. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  60. <p><a href="#">information11</a></p> 
  61. </li> 
  62. <li> 
  63. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  64. <p><a href="#">information12</a></p> 
  65. </li> 
  66. <li> 
  67. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  68. <p><a href="#">information13</a></p> 
  69. </li> 
  70. <li> 
  71. <p><a href="#"><img src="images/1.jpg" alt="#" /></a></p> 
  72. <p><a href="#">information14</a></p> 
  73. </li> 
  74. </ul> 
  75. </div> 
  76. <p class="right_btn"><a href="javascript:void(0)"><img src="images/btn.jpg" /></a></p> 
  77. </div> 
  78. </body> 
  79. <script type="text/javascript"
  80. (function(){ 
  81. var test=new scroll_img('scroll_img',150,590,140,10); 
  82. test.initialize(); 
  83. $('.left_btn').click(function(){ 
  84. test.stop(); 
  85. test.left(); 
  86. test.autoplay(); 
  87. }); 
  88. $('.right_btn').click(function(){ 
  89. test.stop(); 
  90. test.right(); 
  91. test.autoplay(); 
  92. }); 
  93. })(); 
  94. </script> 
  95. </html> 

scroll_img.js如下:

 

 
  1. function scroll_img(target,distance,show_width,li_width,mr){ 
  2. this.distance=distance; //每次移动距离 
  3. this.target=$("#"+target); 
  4. this.show_width=show_width; //显示区域宽度 
  5. this.li_width=li_width; //items宽度 
  6. this.mr=mr; //items间距 
  7. this.scrollbar=$("#"+target).find('ul'); 
  8. this.position=0; 
  9. this.direction=1; 
  10. scroll_img.prototype={ 
  11. version:1.00, 
  12. author:"yangfeifei"
  13. date:2011-11-21, 
  14. initialize:function(){ 
  15. var t=this
  16. t.scrollbar.css('position','relative'); 
  17. //初始动作 
  18. t.autoplay(); 
  19. t.scrollbar.mouseover(function(){t.stop();}); //鼠标移到图片上停止自动播放 
  20. t.scrollbar.mouseout(function(){t.autoplay();}); //鼠标移出图片开始自动播放 
  21. }, 
  22. right:function(){ 
  23. var t=this
  24. (-t.position)<t.total_length()?t.position-=t.distance:t.position=t.position; 
  25. if((-t.position)<t.total_length()){ 
  26. t.scrollbar.animate({left:t.position},500); 
  27. t.direction=1; 
  28. if((-t.position)==t.total_length()){ 
  29. t.scrollbar.animate({left:t.position},500); 
  30. t.direction=-1; 
  31. }, 
  32. left:function(){ 
  33. var t=this
  34. (-t.position)>0?t.position+=t.distance:t.position=t.position; 
  35. if((-t.position)>0){ 
  36. t.scrollbar.animate({left:t.position},500); 
  37. t.direction=-1; 
  38. if((-t.position)==0){ 
  39. t.scrollbar.animate({left:t.position},500); 
  40. t.direction=1; 
  41. }, 
  42. total_length:function(){ 
  43. var t=this
  44. total_num=t.scrollbar.find('li').length; 
  45. return total_num*(t.li_width+t.mr)-(t.mr+t.show_width); 
  46. }, 
  47. autoplay:function(){ 
  48. var t=this
  49. t.setInt=setInterval(function(){ 
  50. t.direction==1?t.right():t.left(); 
  51. },3000); 
  52. }, 
  53. stop:function(){ 
  54. var t=this
  55. clearInterval(t.setInt); 

global.css如下:

 

 
  1. /*CSS reset*/ 
  2. body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;font-family:arial,"宋体";} 
  3. table{border-collapse:collapse;border-spacing:0;} 
  4. fieldset,img{border:0;} 
  5. address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:bold;} 
  6. ol,ul{list-style-type:none;} 
  7. caption,th{text-align:left;} 
  8. h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}/*font-size:100%;的作用主要是改变它默认的大小,继承父体的字体大小*/ 
  9. q:before,q:after{content:' ';} 
  10. abbr,acronym{border:0;} 
  11. .cb{clear:both;} 
  12. .cl{clear:left;} 
  13. .cr{clear:right;} 
  14. .clearfix:after{content:".";display:block;height:0;clear:both;visibility:hidden;} 
  15. .clearfix{display:inline-block;} 
  16. * html .clearfix{height:1%;} 
  17. .clearfix{display:block;} 
  18. /*主体css*/ 
  19. .scroll_img_wrap{width:612px;margin: 10px auto;} 
  20. #scroll_img{width:590px;overflow:hidden;float:left;*position:relative;border: 1px #ccc solid;}/*可视区域宽度*/ 
  21. .scroll_img_list{width:9999px;} 
  22. .scroll_img_list li{float:left;width:140px;margin-right:10px;}/*items*/ 
  23. .scroll_img_list li p{text-align:center;} 
  24. .scroll_img_list li p a{text-decoration:none;color:#666;} 
  25. .left_btn,.right_btn{float:left;} 

希望本文所述对大家的javascript程序设计有所帮助。

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

图片精选