首页 前端知识 JavaScript图片轮播

JavaScript图片轮播

2024-08-23 20:08:44 前端知识 前端哥 302 624 我要收藏

代码在文章最后面(含图片URL)

实现功能

  1. 按向左按钮图片显示上一张
  2. 按向右按钮图片显示下一张
  3. 每隔2000毫秒显示下一张图
  4. 底部三个圆点显示当前的图片的编号

实现流程

  1. 初始化图片数组 创建一个包含图片URL的数组,轮播时会通过这个数组来切换图片。
  2. 创建当前索引变量 这个变量用来追踪当前显示的图片索引。
  3. 创建自动轮播图片函数 该函数负责更改轮播图中显示的图片,并根据当前索引更新指示器的状态。
  4. 创建指示器的函数 此函数在HTML中创建了与图片数量相同的指示器元素,并为第一个指示器添加了active-indicator类,以表示它是活动的。
  5. 下一张图片按钮 当用户点击“下一张”按钮时,这个函数会被触发。它将currentIndex加一,如果索引等于图片数组长度,则将索引重置为0,然后调用showImage函数来更新图片和指示器。
  6. 上一张图片按钮 当用户点击“上一张”按钮时,这个函数会被触发。它将currentIndex减一,如果索引小于0,则将索引设置为图片数组的最后一个元素的索引,然后调用showImage函数来更新图片和指示器。
  7. 创建事件监听器 将这些监听器绑定到“下一张”和“上一张”按钮上,当按钮被点击时,它们会调用相应的函数。
  8. 启动自动轮播 设置了一个定时器,每隔2000毫秒(2秒)调用一次nextImage函数,从而实现图片的自动轮播。

ONGD:通过操作DOM元素,用CSS类来控制显示的图片和当前图片指示器的状态,实现了图片轮播。

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Simple Carousel</title>
<style>
  body {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    margin: 0;
    background-color: #f0f0f0;
  }

  .carousel {
    position: relative;
    width: 300px;
    height: 200px;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  }

  .carousel img {
    width: 100%;
    height: auto;
  }

  .controls {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding: 0 10px;
  }

  .control-button {
    background-color: white;
    color: #333;
    font-size: 20px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  }

  .indicator-container {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
  }

  .indicator {
    background-color: #ccc;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin: 0 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  }

  .active-indicator {
    background-color: black;
  }
</style>
</head>
<body>
<div class="carousel">
  <img src="" alt="Image" id="carousel-image">
  <div class="controls">
    <button class="control-button" id="prev-btn">👈</button>
    <button class="control-button" id="next-btn">👉</button>
  </div>
  <div class="indicator-container" id="indicators"></div>
</div>

<script>
  const images = [
    'https://www.qianduange.cn/upload/article/8319afaf350346a08a4d51b65638e39d.png',
    'https://www.qianduange.cn/upload/article/6b91-ihyxcrp9562392.jpg',
    'https://www.qianduange.cn/upload/article/D-Ac-fyecfam0465124.jpg'
  ];

  let currentIndex = 0;

  function showImage(index) {
    document.getElementById('carousel-image').src = images[index];
    const indicators = document.getElementById('indicators').children;
    for (let i = 0; i < indicators.length; i++) {
      indicators[i].classList.remove('active-indicator');
    }
    indicators[index].classList.add('active-indicator');
  }

  function createIndicators() {
    const indicatorContainer = document.getElementById('indicators');
    for (let i = 0; i < images.length; i++) {
      const indicator = document.createElement('div');
      indicator.classList.add('indicator');
      if (i === 0) {
        indicator.classList.add('active-indicator');
      }
      indicatorContainer.appendChild(indicator);
    }
  }

  function nextImage() {
    currentIndex++;
    if (currentIndex >= images.length) {
      currentIndex = 0;
    }
    showImage(currentIndex);
  }

  function prevImage() {
    currentIndex--;
    if (currentIndex < 0) {
      currentIndex = images.length - 1;
    }
    showImage(currentIndex);
  }

  document.getElementById('next-btn').addEventListener('click', nextImage);
  document.getElementById('prev-btn').addEventListener('click', prevImage);

  // Auto-play functionality
  setInterval(nextImage, 2000);

  createIndicators();
  showImage(currentIndex);
</script>
</body>
</html>

 

 

 

转载请注明出处或者链接地址:https://www.qianduange.cn//article/16616.html
标签
评论
发布的文章

安装Nodejs后,npm无法使用

2024-11-30 11:11:38

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!