js 实现轮播图

该代码示例展示了如何用JavaScript创建一个轮播图,包括自动轮播功能,每2秒切换图片。当鼠标悬停在轮播图上时,自动轮播会暂停,移开鼠标后继续。此外,用户可以通过点击右下角的控件手动切换图片。
摘要由CSDN通过智能技术生成

效果

描述

使用 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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值