系統城裝機大師 - 唯一官網:www.farandoo.com!

當前位置:首頁 > 網絡編程 > JavaScript > 詳細頁面

JavaScript實現輪播圖片完整代碼

時間:2020-03-07來源:電腦系統城作者:電腦系統城

本文實例為大家分享了JavaScript實現輪播圖片的具體代碼,供大家參考,具體內容如下

JS代碼注釋清晰明了,一看就懂!


 
  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <title>最簡單的輪播效果</title>
  7. <style>
  8. * {
  9. margin: 0;
  10. padding: 0
  11. }
  12.  
  13. .box {
  14. width: 500px;
  15. height: 300px;
  16. border: 1px solid #ccc;
  17. margin: 100px auto;
  18. padding: 5px;
  19. }
  20.  
  21. .inner {
  22. width: 500px;
  23. height: 300px;
  24. position: relative;
  25. overflow: hidden;
  26. }
  27.  
  28. .inner img {
  29. width: 500px;
  30. height: 300px;
  31. vertical-align: top
  32. }
  33.  
  34. ul {
  35. width: 1000%;
  36. position: absolute;
  37. list-style: none;
  38. left: 0;
  39. top: 0;
  40. }
  41.  
  42. .inner li {
  43. float: left;
  44. }
  45.  
  46. ol {
  47. position: absolute;
  48. height: 20px;
  49. right: 20px;
  50. bottom: 20px;
  51. text-align: center;
  52. padding: 5px;
  53. }
  54.  
  55. ol li {
  56. display: inline-block;
  57. width: 20px;
  58. height: 20px;
  59. line-height: 20px;
  60. background-color: #fff;
  61. margin: 5px;
  62. cursor: pointer;
  63. }
  64.  
  65. ol .current {
  66. background-color: red;
  67. }
  68. </style>
  69. </head>
  70.  
  71. <body>
  72. <div class="box" id="box">
  73. <div class="inner">
  74. <!--輪播圖-->
  75. <ul>
  76. <li>
  77. <div><img src="img/001.png" alt="JavaScript實現輪播圖片完整代碼"></div>
  78. </li>
  79. <li>
  80. <div><img src="img/1.png" alt="JavaScript實現輪播圖片完整代碼"></div>
  81. </li>
  82. <li>
  83. <div><img src="img/6.png" alt="JavaScript實現輪播圖片完整代碼"></div>
  84. </li>
  85. <li>
  86. <div><img src="img/3.png" alt="JavaScript實現輪播圖片完整代碼"></div>
  87. </li>
  88. <li>
  89. <div><img src="img/4.png" alt="JavaScript實現輪播圖片完整代碼"></div>
  90. </li>
  91.  
  92. </ul>
  93. </div>
  94. </div>
  95. <script>
  96. /**
  97. *
  98. * @param id 傳入元素的id
  99. * @returns {HTMLElement | null} 返回標簽對象,方便獲取元素
  100. */
  101. function my$(id) {
  102. return document.getElementById(id);
  103. }
  104. //獲取各元素,方便操作
  105. var box = my$("box");
  106. var inner = box.children[0];
  107. var ulObj = inner.children[0];
  108. var list = ulObj.children;
  109. var olObj = inner.children[1];
  110. var imgWidth = inner.offsetWidth;
  111. var right = my$("right");
  112. var pic = 0;
  113. //根據li個數,創建小按鈕
  114. for(var i = 0; i < list.length; i++) {
  115. var liObj = document.createElement("li");
  116. //olObj.appendChild(liObj);
  117. liObj.innerText = (i + 1);
  118. liObj.setAttribute("index", i);
  119. //為按鈕注冊mouseover事件
  120. liObj.onmouseover = function() {
  121. //先清除所有按鈕的樣式
  122. for(var j = 0; j < olObj.children.length; j++) {
  123. olObj.children[j].removeAttribute("class");
  124. }
  125. this.className = "current";
  126. pic = this.getAttribute("index");
  127. animate(ulObj, -pic * imgWidth);
  128. }
  129. }
  130. //設置ol中第一個li有背景顏色
  131. //olObj.children[0].className = "current";
  132. //克隆一個ul中第一個li,加入到ul中的最后=====克隆
  133. ulObj.appendChild(ulObj.children[0].cloneNode(true));
  134. var timeId = setInterval(onmouseclickHandle, 4000);
  135. function onmouseclickHandle() {
  136. //如果pic的值是5,恰巧是ul中li的個數-1的值,此時頁面顯示第六個圖片,而用戶會認為這是第一個圖,
  137. //所以,如果用戶再次點擊按鈕,用戶應該看到第二個圖片
  138. if(pic == list.length - 1) {
  139. //如何從第6個圖,跳轉到第一個圖
  140. pic = 0; //先設置pic=0
  141. ulObj.style.left = 0 + "px"; //把ul的位置還原成開始的默認位置
  142. }
  143. pic++; //立刻設置pic加1,那么此時用戶就會看到第二個圖片了
  144. animate(ulObj, -pic * imgWidth); //pic從0的值加1之后,pic的值是1,然后ul移動出去一個圖片
  145.  
  146. }
  147. //設置任意的一個元素,移動到指定的目標位置
  148. function animate(element, target) {
  149. clearInterval(element.timeId);
  150. //定時器的id值存儲到對象的一個屬性中
  151. element.timeId = setInterval(function() {
  152. //獲取元素的當前的位置,數字類型
  153. var current = element.offsetLeft;
  154. //每次移動的距離
  155. var step = 10;
  156. step = current < target ? step : -step;
  157. //當前移動到位置
  158. current += step;
  159. if(Math.abs(current - target) > Math.abs(step)) {
  160. element.style.left = current + "px";
  161. } else {
  162. //清理定時器
  163. clearInterval(element.timeId);
  164. //直接到達目標
  165. element.style.left = target + "px";
  166. }
  167. }, 10);
  168. }
  169. </script>
  170. </body>
  171.  
  172. </html>

精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。

分享到:

相關信息

系統教程欄目

欄目熱門教程

人氣教程排行

站長推薦

熱門系統下載

jlzzjlzz亚洲乱熟在线播放