首页 > 语言 > JavaScript > 正文

jQuery插件boxScroll实现图片轮播特效

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

本文给大家分享的是使用jQuery插件Boxscroll来实现简单的图片轮播特效的代码,非常简单实用,有需要的小伙伴可以参考下。

BoxScroll

常见图片轮播效果的简单实现。可以数字列表控制或者左右按键控制。逻辑很简单,到了尽头得往回跑,看看注释就知道了。

代码如下:

HTML

 

 
  1. <!doctype html> 
  2. <html> 
  3. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  4. <meta content="" name="keywords" /> 
  5. <meta content="" name="description" /> 
  6. <meta name="author" content="codetker" /> 
  7. <head> 
  8. <title>简易图片轮播插件</title> 
  9. <link href="style/reset.css" rel="stylesheet" type="text/css"
  10. <link href="style/style.css" rel="stylesheet" type="text/css"
  11. <script type="text/javascript" src="js/jquery-1.9.1.min.js"></script> 
  12. <script type="text/javascript" src="js/jquery.codetker.boxScroll.js"></script> 
  13. </head> 
  14.  
  15. <body> 
  16. <div class="wrap"
  17. <div class="scrollBox"
  18. <div class="picOuterBox boxStyle"
  19. <div class="arrow arrowLeft">ToLeft</div> 
  20. <div class="arrow arrowRight">ToRight</div> 
  21. <ul class="picInnerBox boxStyle"
  22. <li> 
  23. <a href="" title=""
  24. <img src="images/test.jpg" alt=""
  25. </a> 
  26. </li> 
  27. <li> 
  28. <a href="" title=""
  29. <img src="images/test.jpg" alt=""
  30. </a> 
  31. </li> 
  32. <li> 
  33. <a href="" title=""
  34. <img src="images/test.jpg" alt=""
  35. </a> 
  36. </li> 
  37. <li> 
  38. <a href="" title=""
  39. <img src="images/test.jpg" alt=""
  40. </a> 
  41. </li> 
  42. <li> 
  43. <a href="" title=""
  44. <img src="images/test.jpg" alt=""
  45. </a> 
  46. </li> 
  47. </ul> 
  48. </div> 
  49. <div class="picControl"
  50. <ul> 
  51. <li class="liSelected">1</li> 
  52. <li>2</li> 
  53. <li>3</li> 
  54. <li>4</li> 
  55. <li>5</li> 
  56. </ul> 
  57. </div> 
  58. </div> 
  59. </div> 
  60. <script type="text/javascript"
  61. $(document).ready(function(){ 
  62. $(".scrollBox").boxScroll(); 
  63. }); 
  64. </script> 
  65. </body> 
  66. </html> 

CSS

 

 
  1. @charset "utf-8"
  2. /* CSS Document */ 
  3. body{ 
  4. margin:0 0; 
  5. padding:0 0; 
  6. height:100%; 
  7. width:100%; 
  8. .wrap{ 
  9. font-family:"微软雅黑","宋体", Times, "Times New Roman", serif; 
  10. font-size:14px; 
  11. margin:0 0; 
  12. padding:0 0; 
  13. height:100%; 
  14. width:100%; 
  15. overflow:hidden; 
  16. .boxStyle{/*照片大小*/ 
  17. width: 500px; 
  18. height: 256px; 
  19. .scrollBox{ 
  20. position: relative; 
  21. width: 500px; 
  22. margin: 0 auto; 
  23. .picInnerBox{ 
  24. width: 10000px;/*足够大能放下即可,如果需要上下滚动,改height*/ 
  25. overflow: hidden; 
  26. .picInnerBox li{ 
  27. cursor: pointer; 
  28. float: left; 
  29. .picOuterBox{ 
  30. overflow: hidden; 
  31.  
  32. .arrow{ 
  33. position: absolute; 
  34. top: 45%; 
  35. height: 40px; 
  36. cursor: pointer; 
  37. z-index: 99;  
  38. .arrow:hover{ 
  39. color: #fff; 
  40. .arrowLeft{ 
  41. float: left; 
  42. left: 5%; 
  43. .arrowRight{ 
  44. float: right; 
  45. right: 5%; 
  46. .picControl{ 
  47. overflow: auto; 
  48. width: 100px; 
  49. margin: 0 auto; 
  50. .picControl ul li{ 
  51. cursor: pointer; 
  52. float: left; 
  53. width: 20px; 
  54. height: 20px; 
  55. text-align: center; 
  56. .picControl ul li:hover{ 
  57. color:red; 
  58. .liSelected{ 
  59. color: red; 

JavaScript

 

 
  1. /* 
  2. * boxScroll 0.1 
  3. * 兼容等常见浏览器 
  4. */ 
  5. ;(function($,window,document,undefined){ 
  6. //定义构造函数 
  7. var BoxObj=function(ele,opt){ 
  8. this.$element=ele; //最外层对象 
  9. this.defaults={ 
  10. 'style': 0 ,//滚动样式选择,默认为普通效果 
  11. 'speed': 1 ,//默认为1s 
  12. 'direction''left',//默认为向左边滚动 
  13. 'toLeft':$(ele).children('.picOuterBox').children('.arrowLeft'),//默认格式下重要位置 
  14. 'toRight':$(ele).children('.picOuterBox').children('.arrowRight'), 
  15. 'ControlUl':$(ele).children('.picControl').children('ul'
  16. }, 
  17.  
  18. this.options=$.extend({},this.defaults,opt ); 
  19. //这里可以添加一些通用方法  
  20.  
  21. //给构造函数添加方法 
  22. BoxObj.prototype={ 
  23.  
  24. commonScroll:function(){ 
  25. //接收对象属性 
  26. var boxWindow=$(this.$element).children('.picOuterBox').children('.picInnerBox'); 
  27. var speed=this.defaults.speed; 
  28. var style=this.defaults.style; 
  29. var direction=(this.defaults.direction=='left')? 1 : -1; 
  30. var toLeft=this.defaults.toLeft; 
  31. var toRight=this.defaults.toRight; 
  32. var Control=this.defaults.ControlUl; 
  33.  
  34. var boxWidth=$(boxWindow).children('li').width(); 
  35. var imgIndexMax=$(boxWindow).children('li').length; 
  36. var imgIndex; 
  37. function getImgIndex(){//判断当前图片的位置 
  38. imgIndex=Math.round(parseInt($(boxWindow).css("margin-left"))*(-1)/boxWidth); 
  39.  
  40. var timer;//必须在外面定义保证全局针对这一功能只有这一个计时器 
  41. timer=setInterval(function(){ 
  42. boxScroll(imgIndex,direction); 
  43. },5000); 
  44.  
  45. function rest(){ 
  46. clearInterval(timer); 
  47. timer=setInterval(function(){ 
  48. boxScroll(imgIndex,direction); 
  49. },5000); 
  50.  
  51. //绑定点击按钮 
  52. $(Control).delegate('li''click'function() { 
  53. boxScroll($(this).index(),0); 
  54. rest(); 
  55. }); 
  56.  
  57. //绑定左右按钮 
  58. $(toLeft).click(function() { 
  59. boxScroll(0,-1); 
  60. rest(); 
  61. }); 
  62. $(toRight).click(function() { 
  63. boxScroll(0,1); 
  64. rest(); 
  65. }); 
  66.  
  67. function boxScroll(index,dir){ 
  68. if (!$(boxWindow).is(':animated')) {//当ul窗口没有在动时 
  69. if(!dir){//响应ul li control操作 
  70. //此时dir=0,则依靠传入的imgIndex 
  71. imgIndex=index; 
  72. //其它时候dir!=0,则依靠dir 
  73. }else{//响应toLeft和toRight 
  74. if(dir==1){//向右动 
  75. getImgIndex(); 
  76. if (imgIndex==(imgIndexMax-1)) { 
  77. imgIndex=0; 
  78.  
  79. }else
  80. imgIndex+=1; 
  81. }else{//向左动 
  82. getImgIndex(); 
  83. if (imgIndex==0) { 
  84. imgIndex=(imgIndexMax-1); 
  85. }else
  86. imgIndex-=1; 
  87. $(Control).children('li').eq(imgIndex).addClass('liSelected'); 
  88. $(Control).children('li').eq(imgIndex).siblings().removeClass('liSelected'); 
  89. $(boxWindow).animate({ 
  90. "margin-left":imgIndex*boxWidth*(-1)+'px' 
  91. }, 1000*speed); 
  92.  
  93. //在插件中使用windowObj对象的方法,0为vertical,1为horizontal 
  94. $.fn.boxScroll=function(options){ 
  95. //创建实体 
  96. var boxObj=new BoxObj(this,options); 
  97. //用尾调的形式调用对象方法 
  98. return boxObj.commonScroll(); 
  99. })(jQuery,window,document); 

详细下载参见https://github.com/codetker/myBoxScroll。

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

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

图片精选