系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网络编程 > 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图片轮播

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

分享到:

相关信息

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载