js 实现轮播图

效果

描述

使用 JavaScript 实现轮播图效果:

  • 自动轮播:每隔 2s,自动切换图片
  • 鼠标进入轮播图区域,暂停自动轮播(一直显示当前图片)
  • 鼠标离开轮播图区域,继续自动轮播
  • 点击轮播图区域右下角轮播控件,切换为对应图片

代码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>轮播图</title>
		<style>
			* {
				margin: 0;
				padding: 0;
			}
			
			html {
				font-size: 62.5%;
			}
			
			.carousel-bar {
				width: 48rem;
				height: 27rem;
				border: 1px solid #676767;
				margin: 3rem auto;
				position: relative;
			}
			
			.carousel-image-list {
				width: 100%;
				height: 100%;
				display: flex;
				overflow: hidden;
			}
			
			.carousel-image {
				width: 48rem;
				height: 27rem;
			}
			
			.carousel-control-list {
				display: flex;
				position: absolute;
				bottom: 1rem;
				right: 1.2rem;
			}
			
			.carousel-control {
				font-size: 1.5rem;
				color: #fff;
				background-color: rgba(0, 0, 0, 0.5);
				margin: 0 0.2rem;
				padding: 0.2rem 0.7rem;
				border-radius: 0.2rem;
				cursor: pointer;
			}
		</style>
	</head>
	<body>
		<div class="carousel-bar">			
			<div class="carousel-image-list">
				<div><img src="./img/487211.jpg" alt="" class="carousel-image"></div>
				<div><img src="./img/520426.jpg" alt="" class="carousel-image"></div>
				<div><img src="./img/580153.jpg" alt="" class="carousel-image"></div>
				<div><img src="./img/692649.jpg" alt="" class="carousel-image"></div>
				<div><img src="./img/837663.jpg" alt="" class="carousel-image"></div>
			</div>
			
			<div class="carousel-control-list">
				<div class="carousel-control">1</div>
				<div class="carousel-control">2</div>
				<div class="carousel-control">3</div>
				<div class="carousel-control">4</div>
				<div class="carousel-control">5</div>
			</div>
		</div>
		
		<script>
			let carouselBar = document.getElementsByClassName("carousel-bar")[0];
			let imageList = document.getElementsByClassName("carousel-image-list")[0];
			let image = document.getElementsByClassName("carousel-image");
			let control = document.getElementsByClassName("carousel-control");
			
			let imageIndex = 0;
			
			/**
			 * @description 显示指定的图片
			 * @param {Number} index 要显示的图片的索引
			 */
			function showImage(index) {
				imageIndex = index;
				
				/* 显示第 index 张图片(将图片列表水平向左滚动) */
				imageList.scrollLeft = imageList.offsetWidth * index;
				
				/* 为控件添加样式 */
				for(let i=0; i<control.length; i++){
					if(i == index){
						/* 为当前控件添加样式 */
						control[i].style.boxShadow = "0 0 0 0.1rem #f00";
					}else{
						/* 将其它控件恢复为默认样式 */
						control[i].style.boxShadow = "0 0 0 0 #f00";
					}
				}
			}
			
			/* 页面默认显示第一张图片 */
			showImage(0);
			
			/* 手动轮播,点击轮播控件中的不同数字,切换为对应的图片 */
			for(let i=0; i<control.length; i++){
				control[i].onclick = function(){
					showImage(i);
				}
			}
			
			/* 自动轮播 */
			/**
			 * @description 播放下一张图片
			 */
			function autoPlay(){
				imageIndex++;
				
				/* 将最后一张图片的下一张图片设置为第一张图片 */
				if(imageIndex > image.length-1){
					imageIndex = 0;
				}
				
				showImage(imageIndex);
			}
			/* 周期性调用 autoPlay 函数,实现自动播放 */
			let interval = setInterval(autoPlay, 2000);
			
			/* 鼠标进入轮播图区域,暂停自动播放 */
			carouselBar.onmouseover = function(){
				clearInterval(interval);
			}
			
			/* 鼠标离开轮播图区域,继续自动播放 */
			carouselBar.onmouseout = function(){
				interval = setInterval(autoPlay, 2000);
			}
		</script>
	</body>
</html>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的基于JavaScript实现轮播图示例: HTML结构: ```html <div class="slider"> <ul class="slides"> <li><img src="image1.jpg"></li> <li><img src="image2.jpg"></li> <li><img src="image3.jpg"></li> </ul> </div> ``` CSS样式: ```css .slider { position: relative; width: 100%; height: 500px; overflow: hidden; } .slides { position: absolute; top: 0; left: 0; width: 300%; height: 100%; display: flex; transition: all 0.5s ease-in-out; } .slides li { width: 33.333%; list-style: none; } .slides img { width: 100%; height: 100%; object-fit: cover; } ``` JavaScript代码: ```javascript const slider = document.querySelector('.slider'); const slides = document.querySelectorAll('.slides li'); let currentSlide = 0; function nextSlide() { slides[currentSlide].classList.remove('active'); currentSlide = (currentSlide + 1) % slides.length; slides[currentSlide].classList.add('active'); slider.style.transform = `translateX(-${currentSlide * 100}%)`; } setInterval(nextSlide, 3000); ``` 这个示例中,我们通过JavaScript代码来实现轮播图的自动播放效果。我们首先获取到了轮播图的容器(`.slider`)以及轮播图中的每一张图片(`.slides li`)。 我们定义了一个 `currentSlide` 变量来表示当前显示的图片序号,然后编写了一个 `nextSlide` 函数,在每次自动播放时都会被调用。这个函数首先移除当前显示的图片的 `active` 类,然后计算出下一张图片的序号,并为其添加 `active` 类。最后,我们通过设置容器的 `transform` 属性来移动图片,实现轮播效果。 最后,我们使用 `setInterval` 方法来每隔3秒钟调用一次 `nextSlide` 函数,从而实现轮播图的自动播放。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值