JS 图片的左右切换

图片的左右切换

复制代码
<div class="slider">
  <img src="image1.jpg" alt="Image 1">
  <img src="image2.jpg" alt="Image 2">
  <img src="image3.jpg" alt="Image 3">
</div>
<button id="prevBtn">Previous</button>
<button id="nextBtn">Next</button>

.slider {
  position: relative;
  width: 500px;
  height: 300px;
  overflow: hidden;
}

.slider img {
  width: 100%;
  height: auto;
  display: none;
}

.slider img.active {
  display: block;
}

 <script type="text/javascript">
// 获取相关元素
var slider = document.querySelector('.slider');
var prevBtn = document.getElementById('prevBtn');
var nextBtn = document.getElementById('nextBtn');
var images = slider.getElementsByTagName('img');
var currentIndex = 0;

// 显示当前图片
function showImage(index) {
  // 移除所有图片的active类
  for (var i = 0; i < images.length; i++) {
    images[i].classList.remove('active');
  }
  // 添加当前图片的active类
  images[index].classList.add('active');
}

// 点击上一张按钮
prevBtn.addEventListener('click', function() {
  currentIndex--;
  if (currentIndex < 0) {
    currentIndex = images.length - 1;
  }
  showImage(currentIndex);
});

// 点击下一张按钮
nextBtn.addEventListener('click', function() {
  currentIndex++;
  if (currentIndex >= images.length) {
    currentIndex = 0;
  }
  showImage(currentIndex);
});

// 显示初始图片
showImage(currentIndex);

</script>
相关推荐
天生我材必有用_吴用2 分钟前
vue3实战三、Axios封装结合mock数据,vite跨域及环境变量配置 入口
前端
天生我材必有用_吴用3 分钟前
vue3实战二、搭建Vue+ElementPlus项目教程 入口
前端
天生我材必有用_吴用7 分钟前
Vue3实战七、登录认证与退出登录
前端
逆袭的小黄鸭8 分钟前
JavaScript DOM 事件流:从基础传播到高级控制与自定义实践
前端·javascript
H5开发新纪元9 分钟前
基于Ant Design Pro高级表格的企业级代理商管理系统开发实践
前端
泉城老铁11 分钟前
springboot对接钉钉,发送钉钉消息
java·前端·后端
whoarethenext12 分钟前
基于libevent写一个服务器(附带源码)
linux·运维·服务器·c++·后端
天生我材必有用_吴用19 分钟前
vue3实战六、外链跳转404,401等 入口
前端
天生我材必有用_吴用23 分钟前
vue3实战五、面包学,收缩菜单,暗黑高亮主题切换,全屏非全屏实现 入口
前端
WEI_Gaot27 分钟前
css的选择器和优先级
前端·css