当前位置:   article > 正文

JavaScript轮播图

JavaScript轮播图

HTML部分

  1. <div class="box" onmouseover="over()" onmouseout="noover()">
  2. <img src="./img/zuo.png" alt="" class="left_arrow" onclick="left_last()">
  3. <img src="./img/yy.png" alt="" class="right_arrow" onclick="right_word()">
  4. <div id="carousel">
  5. </div>
  6. <div class="round">
  7. </div>
  8. </div>

JavaScript部分:携带注释哟家人们

  1. <script>
  2. let data; // 声明一个变量用于存储从服务器获取的数据
  3. let k = 0; // 当前显示的图片索引
  4. let imgwidth; // 图片宽度
  5. let imgheight; // 图片高度
  6. let inter; // 用于存储定时器的变量
  7. // 创建一个XMLHttpRequest对象用于发送请求
  8. let xhr = new XMLHttpRequest();
  9. // 设置请求方式和请求地址
  10. xhr.open('get', './js/banner.json', true);
  11. // 发送请求
  12. xhr.send();
  13. // 接收返回的响应数据
  14. xhr.onreadystatechange = function() {
  15. if (xhr.readyState == 4 && xhr.status == 200) {
  16. let text = xhr.responseText;
  17. // 将获取的文本数据转换为JSON格式
  18. data = JSON.parse(text);
  19. // 调用展示图片的函数
  20. console.log(data); // 打印获取到的数据到控制台
  21. // 调用展示图片的函数
  22. show(data);
  23. }
  24. };
  25. // 获取轮播图容器元素
  26. let carsoule = document.getElementById('carousel');
  27. function show(data) {
  28. let str = ``; // 声明一个空字符串用于存储要渲染的图片标签
  29. let sti = ``; // 声明一个空字符串用于存储轮播图指示器的标签
  30. for (let i = 0; i < data.imge.length; i++) {
  31. // 渲染图片到页面中
  32. str += `<img src="${data.imge[i]}" alt="" class="img_carousel">`;
  33. // 根据索引,渲染轮播图指示器
  34. if (i == 0) {
  35. sti += `<div style="background-color: aqua;"></div>`;
  36. } else {
  37. sti += `<div></div>`;
  38. }
  39. }
  40. // 将最后一张图片再次添加到轮播图容器中,用于实现循环播放
  41. str += `<img src="${data.imge[0]}" alt="">`;
  42. // 将图片和轮播图指示器渲染到页面中
  43. document.getElementById('carousel').innerHTML = str;
  44. document.getElementsByClassName('round')[0].innerHTML = sti;
  45. // 获取第一张图片的宽度
  46. imgwidth = document.getElementsByClassName('img_carousel')[0].offsetWidth;
  47. // 调用轮播功能
  48. noover();
  49. }
  50. // 获取轮播图指示器的所有子元素
  51. let dots = document.getElementsByClassName('round')[0].children;
  52. // 下一张图片函数
  53. function next() {
  54. k++; // 索引加1,显示下一张图片
  55. carsoule.style.marginLeft = "-" + imgwidth * k + "px"; // 设置轮播图容器的左边距
  56. carousel.style.transition = "margin-left 1s"; // 设置过渡效果
  57. // 如果达到最后一张图片,回到第一张图片
  58. if (k == data.imge.length) {
  59. setTimeout(function() {
  60. carousel.style.transition = "none"; // 去掉过渡效果
  61. k = 0; // 将索引设置为0,回到第一张图片
  62. carousel.style.marginLeft = `-${k * 100}%`; // 设置轮播图容器的左边距
  63. }, 1000);
  64. }
  65. // 根据索引,设置轮播图指示器的样式
  66. if (k < dots.length) {
  67. dots[k].style.background = "aqua"; // 当前图片指示器背景颜色为aqua
  68. dots[k - 1].style.background = "pink"; // 上一张图片指示器背景颜色为pink
  69. } else if (k == dots.length) {
  70. dots[0].style.background = "aqua"; // 第一张图片指示器背景颜色为aqua
  71. dots[k - 1].style.background = "pink"; // 最后一张图片指示器背景颜色为pink
  72. k = 0; // 将索引设置为0,回到第一张图片
  73. }
  74. }
  75. // 自动轮播函数
  76. function noover() {
  77. inter = setInterval(next, 2000); // 每2秒调用一次next函数,实现自动轮播
  78. }
  79. // 鼠标悬停在轮播图上,停止自动轮播
  80. function over() {
  81. clearInterval(inter); // 清除定时器,停止自动轮播
  82. }
  83. // 获取右箭头元素
  84. let right = document.getElementsByClassName('right_arrow')[0];
  85. // 点击右箭头切换到下一张图片
  86. function right_word() {
  87. right.onclick = null; // 防止连续点击
  88. next(); // 调用下一张图片函数
  89. // 1.5秒后恢复右箭头的点击事件
  90. setTimeout(function() {
  91. right.onclick = right_word;
  92. }, 1500);
  93. }
  94. // 获取左箭头元素
  95. // let left = document.getElementsByClassName('left_arrow')[0];
  96. // 点击左箭头切换到上一张图片
  97. function left_last() {
  98. k--; // 索引减1,显示上一张图片
  99. // 如果索引小于0,回到最后一张图片
  100. if (k < 0) {
  101. k = dots.length; // 将索引设置为指示器数量,显示最后一张图片
  102. carousel.style.transition = ""; // 去掉过渡效果
  103. carsoule.style.marginLeft = "-" + imgwidth * k + "px"; // 设置轮播图容器的左边距
  104. // 0.01秒后,过渡效果生效,显示倒数第二张图片
  105. setTimeout(function() {
  106. k--; // 索引减1,显示倒数第二张图片
  107. carousel.style.transition = "all 1s"; // 添加过渡效果
  108. carsoule.style.marginLeft = "-" + imgwidth * k + "px"; // 设置轮播图容器的左边距
  109. dots[k].style.background = "aqua"; // 当前图片指示器背景颜色为aqua
  110. dots[0].style.background = "pink"; // 第一张图片指示器背景颜色为pink
  111. }, 10);
  112. } else {
  113. carousel.style.transition = "all 1s"; // 添加过渡效果
  114. carsoule.style.marginLeft = "-" + imgwidth * k + "px"; // 设置轮播图容器的左边距
  115. dots[k].style.background = "aqua"; // 当前图片指示器背景颜色为aqua
  116. dots[k + 1].style.background = "pink"; // 下一张图片指示器背景颜色为pink
  117. }
  118. }
  119. </script>

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Li_阴宅/article/detail/945079
推荐阅读
相关标签
  

闽ICP备14008679号