超简单的轮播图动画效果 HTML+Css

轮播图在电商方面应用的非常广泛,那么该如何去写呢?接下来我们就看一下制作轮播图(bannner)的详细方法。

所谓轮播图就是将n张图面进行一个移动切换; 

废话不多说上代码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title></title>
		<style>
			.banner {
				width: 500px;
				height: 300px;
				overflow: hidden;
			}

			.box {
				width: 400%;
				height: 300px;
				animation: banner 5s infinite;
			}

			.box img {
				width: 25%;
				height: 300px;
				float: top;
			}

			@keyframes banner {
				0% {
					margin-left: 0px;
				}

				33.3% {
					margin-left: -100%;
				}

				66.6% {
					margin-left: -200%;
				}

				100% {
					margin-left: -300%;
				}
			}
		</style>
	</head>
	<body>

		<div class="banner">
			<div class="box">
				<img src="41c406dcb2f628db97bc64bf84c6e906_38bf42ad37a6eba0b927e10e8d544ac498e9c4c0.jpg" alt="">
				<img src="41c406dcb2f628db97bc64bf84c6e906_38bf42ad37a6eba0b927e10e8d544ac498e9c4c0.jpg" alt="">
				<img src="41c406dcb2f628db97bc64bf84c6e906_38bf42ad37a6eba0b927e10e8d544ac498e9c4c0.jpg" alt="">

				<img src="41c406dcb2f628db97bc64bf84c6e906_38bf42ad37a6eba0b927e10e8d544ac498e9c4c0.jpg" alt="">
			</div>
		</div>
<!-- 动画:
		animation: 名称 过渡时间 方式 次数 开始时间;
                   名称 	要和规则的名称一致
                   过渡时间   一次动画所用到的时间  s
				   方式   linear  平缓
						   ease   默认,慢 - 快 - 慢
				   次数 	数字 或 infinite无限的
				   开始时间   几秒后开始  s
					
				规则
					@keyframes 名称{
						from{ 开始时的样式 }
						to{ 结束时的样式 }
					}
					
					@keyframes box{
						0%{  }
						25%{  }
						50%{  }
						75%{  }
						100%{  }
					}
					
			 -->
	</body>
</html>

css的轮播图动画呢是自动轮播他的原理也很简单 他主要就是animation和keyframes ,transform:translate();的应用

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
轮播图是网页中常用的展示图片或内容的方式,需要结合JavaScript、HTMLCSS来实现。以下是一个简单轮播图实现过程: 1. HTML结构 ```html <div class="slider"> <ul class="slides"> <li><img src="img1.jpg"></li> <li><img src="img2.jpg"></li> <li><img src="img3.jpg"></li> </ul> </div> ``` 其中,`.slider`是整个轮播图的容器,`.slides`是图片列表的容器,`<li>`标签包裹每张图片。 2. CSS样式 ```css .slider { width: 600px; height: 300px; overflow: hidden; position: relative; } .slides { width: 300%; height: 100%; position: relative; left: 0; } .slides li { width: 33.3333%; height: 100%; float: left; } .slides img { width: 100%; height: 100%; object-fit: cover; } ``` `.slider`容器设置宽高和`overflow:hidden`属性,使得图片列表可以在容器内滑动,`.slides`设置宽度为图片宽度的3倍,每张图片的宽度为33.3333%,让图片列表在容器内可以滑动,`.slides img`设置图片宽高100%填满列表容器。 3. JavaScript实现 ```javascript let slides = document.querySelectorAll('.slides li'); let currentSlide = 0; let slideInterval = setInterval(nextSlide, 3000); function nextSlide() { slides[currentSlide].classList.remove('active'); currentSlide = (currentSlide + 1) % slides.length; slides[currentSlide].classList.add('active'); } ``` 获取所有图片列表项,设置当前图片下标和切换时间间隔。`nextSlide`函数实现切换图片的逻辑,移除当前图片的`active`类,下标加1,取余数得到下一个图片的下标,给下一个图片添加`active`类。 4. CSS动画效果 ```css .slides { transition: transform 0.5s ease-in-out; } .slides.active { transform: translateX(-33.3333%); } ``` `.slides`设置`transition`属性,使得图片列表在切换时有过渡效果,`.slides.active`设置`transform`属性,实现图片列表在切换时的滑动效果。 以上就是一个简单轮播图实现过程,可以根据实际需求进行扩展和优化。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bug丶小狼人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值