首页 > 语言 > JavaScript > 正文

js实现使用鼠标拖拽切换图片的方法

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

这篇文章主要介绍了js实现使用鼠标拖拽切换图片的方法,涉及javascript操作图片实现轮播效果的相关技巧,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了js实现使用鼠标拖拽切换图片的方法。分享给大家供大家参考。具体实现方法如下:

 

 
  1. <script type="text/javascript" src="js/jquery.min.js"></script> 
  2. <style type="text/css"
  3. *{margin:0;padding:0;} 
  4. .m-slider{width:600px;margin:0 auto 10px !important;} 
  5. #slider{width:100%; overflow:hidden;} 
  6. .m-slider .cnt{position:relative;left:0;width:2000%;} 
  7. .m-slider .cnt li{float:left;width:5%; height: 450px; 
  8. overflow: hidden; 
  9. .m-slider .cnt img{ 
  10. display:block;width:100%;height:450px; 
  11. vertical-align:top; 
  12. .m-slider .cnt p{margin:10px 0;} 
  13. .m-slider .icons{text-align:center;color:#000; 
  14. position: relative; z-index: 999; margin-top: -20px; 
  15. .m-slider .icons span{ 
  16. background: #fff; border-radius: 5px; 
  17. box-shadow: 0 0 2px #b0b0b0 inset; display: inline-block; 
  18. height: 10px; margin: 0 5px; overflow: hidden; 
  19. text-indent: -99em; width: 10px; 
  20. .m-slider .icons .curr{ 
  21. background:#f80; box-shadow: 0 0 2px #f60 inset 
  22. </style> 
  23. <div class="m-slider"
  24. <div id="slider"
  25. <ul id="m-slider" class="cnt"
  26. <li><a href="#1"><img src="images/mofe.jpg" alt="" /></a></li> 
  27. <li><a href="#2"><img src="images/9hll.jpg" alt="" /></a></li> 
  28. <li><a href="#3"><img src="images/p2bb.jpg" alt="" /></a></li> 
  29. <li><a href="#4"><img src="images/3srp.jpg" alt="" /></a></li> 
  30. <li><a href="#1"><img src="images/ft9s.jpg" alt="" /></a></li> 
  31. </ul> 
  32. </div> 
  33. <div id="icons" class="icons"><span class="curr">1</span> 
  34. <span>2</span> <span>3</span> <span>4</span> <span>5</span> 
  35. </div> 
  36. </div> 
  37. <script type="text/javascript"
  38. jQuery(document).ready(function($){ 
  39. var $slider = $('#m-slider'); 
  40. var $icons = $('#icons'); 
  41. var $li = $slider.children('li'); 
  42. var WIDTH = $li.width(); 
  43. var SIZE = $li.size(); 
  44. $slider.append($li.first().clone()); 
  45. //console.log(WIDTH + '-' + SIZE); 
  46. var ox,mx,ux,sumx,scroll,i=0,bool=false,staut=true
  47. $li.find('a').click(function(){ 
  48. //阻止轮播元素的默认点击事件 
  49. return false
  50. }); 
  51. $slider.mousedown(function(e){ 
  52. //鼠标左键轮播区域 
  53. if(e.target.tagName == 'IMG' && e.button == 0){ 
  54. //左键图片 
  55. staut = true
  56. //初始化拖拽,状态为true,可以触发点击事件 
  57. sumx = 0; 
  58. //初始化鼠标偏移为0 
  59. bool = true
  60. //记录左键状态 
  61. ox = e.pageX; 
  62. //记录鼠标初始坐标 
  63. scroll = $slider.parent().scrollLeft(); 
  64. //记录初始轮播水平滚动偏移 
  65. e.preventDefault(); 
  66. //阻止鼠标点击默认事件 
  67. }); 
  68. $slider.mousemove(function(e){ 
  69. //鼠标在轮播区域移动 
  70. if(bool){//左键状态 
  71. staut = false
  72. //已经拖拽,状态为false,不再触发点击事件 
  73. mx = e.pageX; 
  74. //记录鼠标实时坐标 
  75. sumx = ox - mx; 
  76. //记录鼠标坐标偏移 
  77. $slider.parent().scrollLeft(scroll+sumx); 
  78. }); 
  79. $slider.mouseout(function(e){ 
  80. //鼠标离开轮播区域 
  81. if(bool){ 
  82. //左键状态 
  83. staut = true
  84. //已经拖拽,但是离开了轮播区域, 
  85. //状态为true,可以触发点击事件 
  86. bool = false;//释放左键状态 
  87. sumx > 0 && i < SIZE && i++;//下一个 
  88. sumx < 0 && i > 0 && i--;//上一个 
  89. $slider.parent().stop().animate({scrollLeft:i*WIDTH},300,function(){ 
  90. if(i == SIZE){ 
  91. i = 0; 
  92. $slider.parent().scrollLeft(0); 
  93. $icons.find('.curr').removeClass('curr').end().children().eq(i).addClass('curr'); 
  94. });//完成拖拽 
  95. }); 
  96. $slider.mouseup(function(e){ 
  97. //鼠标释放,完成click事件 
  98. bool = false
  99. //释放左键状态 
  100. if(staut && e.button == 0){ 
  101. //没有拖拽或者拖拽失效,且是左键,触发点击事件 
  102. window.location.href = $(e.target).parent().attr('href'); 
  103. //触发点击事件 
  104. }else if(!staut && e.button == 0){ 
  105. //成功拖拽,且是左键 
  106. sumx > 0 && i < SIZE && i++;//下一个 
  107. sumx < 0 && i > 0 && i--;//上一个 
  108. $slider.parent().stop().animate({scrollLeft:i*WIDTH},300,function(){ 
  109. if(i == SIZE){ 
  110. //最后一个 
  111. i = 0; 
  112. $slider.parent().scrollLeft(0);//归位 
  113. $icons.find('.curr').removeClass('curr').end().children().eq(i).addClass('curr'); 
  114. });//完成拖拽 
  115. }); 
  116. function setSlider(){ 
  117. i < SIZE && i++;//下一个 
  118. $slider.parent().stop().animate({scrollLeft:i*WIDTH},300,function(){ 
  119. if(i == SIZE){//最后一个 
  120. i = 0; 
  121. $slider.parent().scrollLeft(0); 
  122. $icons.find('.curr').removeClass('curr').end().children().eq(i).addClass('curr'); 
  123. });//完成拖拽 
  124. var timer = setInterval(function(){ 
  125. setSlider(); 
  126. },3000); 
  127. $slider.hover(function(){ 
  128. if(timer){ 
  129. clearInterval(timer); 
  130. timer = null
  131. },function(){ 
  132. timer = setInterval(function(){ 
  133. setSlider(); 
  134. },3000); 
  135. }); 
  136. $(window).resize(function(){ 
  137. WIDTH = $li.width(); 
  138. $slider.parent().scrollLeft(i*WIDTH);//归位 
  139. //console.log(WIDTH + '-' + i); 
  140. }); 
  141. }); 
  142. </script> 

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

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

图片精选