国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > 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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 巴彦淖尔市| 尼木县| 雅安市| 罗山县| 托克逊县| 江永县| 克东县| 淳安县| 兖州市| 米林县| 丹阳市| 丰原市| 长泰县| 淮阳县| 双流县| 乐清市| 嘉荫县| 广南县| 凤山市| 惠州市| 涟水县| 壶关县| 德清县| 游戏| 若羌县| 奈曼旗| 喀喇沁旗| 延津县| 日照市| 太谷县| 唐山市| 临洮县| 连州市| 永安市| 乳山市| 叙永县| 固原市| 汾阳市| 达日县| 云林县| 调兵山市|