简易轮播图

简易轮播图效果:
4张图片间隔一秒,依次呈现,鼠标在按钮悬停,可更改至指定图片
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
		    .main {
		        width: 350px;
		        height: 300px;
		        overflow: hidden;
		        position: relative;
		    }
		
		    ul li {
		        list-style: none;
		    }
		
		    .main ul#picid img {
		        width: 350px;
		        height: 300px;
		        border: 1px solid red;
		    }
		
		    .main #numid {
		        position: absolute;
		        left: 10px;
		        bottom: 5px;
		    }
		
		    .main ul#numid li {
		        width: 17px;
		        height: 17px;
		        border: 1px solid blue;
		        background-color: white;
		        color: blue;
		        font-size: 14px;
		        float: left;
		        margin-left: 8px;
		        text-align: center;
		        line-height: 17px;
		    }
		    .active {
		        color: pink;
		        background-color: pink;
		        cursor: pointer;
		        font-weight: bold;
		    }
		</style>
		<!-- 
		 type:JavaScript告诉浏览器:"我是 js文件"  H5之后可以不写,不影响
		 src:引用在线:src="http://code.jquery.com/jquery-latest.js"
			 引用本地:本地文件
		-->
		
		<script type="text/javascript" src="js/jquery-1.11.0.min.js"></script>
		<script>
		$(function(){
			//目的 要求鼠标移到上方就改变图片
			var flag=false;
			// 自动轮播图的索引值
			var time=0;
			
			//获取id下的li的对象数组
			var pic=$("#picid").children("li");
			var num=$("#numid").children("li");
			
			//鼠标方法上就会触发这个函数
			
			num.mouseover(function(){
				//鼠标在按钮上悬浮判断 true 
				flag=true;
				//获取当前鼠标选择的对象的索引
				var index=num.index($(this));
				
				//获取了index传给图片进行更改相对应的索引值
				pic.eq(index).stop(true,true).fadeIn().siblings().fadeOut();
				num.eq(index).addClass("active").stop(true,true).siblings().removeClass("active");
				
			
		
			num.mouseout(function(){
					flag=false;
					
						
				})
			})	
		setInterval(function(){
			//是true之后停止轮播,直接返回return结束函数
			if(flag==true){
				return;
			}
			time++;
			
			//判断索引是否小于<4 大于4就归0,重新循环
			if(time<4){
				pic.eq(time).stop(true,true).fadeIn().siblings().fadeOut();
				num.eq(time).addClass("active").stop(true,true).siblings().removeClass("active");
			}else{
				time=0;
				pic.eq(time).stop(true,true).fadeIn().siblings().fadeOut();
				num.eq(time).addClass("active").stop(true,true).siblings().removeClass("active");
			}
			
		},1000);
		
	/* 
	总结:
	淡入浅出效果来显示被选元素:fadeIn()、fadeOut()
		fadeIn(speed,callback): speed : 可选。规定元素从隐藏到可见的速度  callback:可选。fadeIn 函数执行完之后,要执行的函数。
		
		siblings()函数用于选取每个匹配元素的所有同辈元素(不包括自己),并以jQuery对象的形式返回
		
		addClass()方法,增加样式、用于动态增加class类名
		
		removeClass()方法、删除样式、,用于动态删除class类名
		
		
	
		1、明确自己每一步都要实现的目的是什么
		2、明白每一行的返回值和返回值类型
		3、写注释是一个好习惯
		4、第二次复习写,还算顺利,自己的思路写下的不同于模板,碰到bug不应该烦躁,我想我应该会是一个不错的问题解决者
	 */
		
		})
		</script>

				

	</head>
	<body>
		<div class="main">
		    <ul id="picid">
		        <li><a href=""><img src="images/list1.jpg" alt="" /></a></li>
		        <li><a href=""><img src="images/list2.jpg" alt="" /></a></li>
		        <li><a href=""><img src="images/list3.jpg" alt="" /></a></li>
		        <li><a href=""><img src="images/list4.jpg" alt="" /></a></li>
		    </ul>
		    <ul id="numid">
		        <li>1</li>
		        <li>2</li>
		        <li>3</li>
		        <li>4</li>
		    </ul>
		</div>
	</body>
</html>

<think>好的,我需要帮助用户创建一个简易HTMLCSS轮播图。用户提到了之前的引用,里面提到了两种方法:一种是使用CSS切换图片,另一种是切割轮播图。用户现在想要一个简单的教程,所以应该选择更基础的方法开始。 首先,轮播图的基本结构通常包括一个容器包裹图片,可能还有导航点或按钮。根据引用[1],用户使用了一个div容器,里面包含ul和ol分别对应图片和圆点。不过,对于简易版本,可能不需要太复杂的结构。可以考虑用div包裹图片,然后用CSS控制显示。 接下来,CSS部分需要隐藏非活动的图片,并通过类名(如.active)来控制当前显示的图片。可能需要使用Flexbox或者绝对定位来让图片重叠,然后通过透明度或z-index的变化来实现切换效果。引用[1]和[3]提到了使用背景图片和动画,但用户可能需要更直接的img标签方法。 另外,引用[2]和[3]提到的切割轮播图涉及更复杂的3D变换,可能对新手来说有点难。所以应该先教基础版本,使用简单的过渡效果。例如,通过JavaScript切换类名,或者使用CSS的:hover伪类,但交互性可能不够,所以最好用JS控制。 还需要考虑导航按钮,比如左右箭头和圆点指示器。引用[1]中的示例用了ol和li来创建圆点,可以通过点击事件切换图片。JavaScript部分需要处理点击事件,改变当前显示的图片索引,并更新active类。 最后,自动轮播功能可以通过setInterval实现,但用户可能希望先掌握手动切换。所以教程应该分步骤,先做静态结构,再加样式,最后用JS实现交互。 需要检查代码的正确性,确保图片正确排列,过渡效果平滑,并且导航元素工作正常。可能还需要处理图片的预加载和响应式设计,但简易版本可能暂时不需要这些高级功能。 总结步骤:HTML结构搭建(容器、图片、导航点)→ CSS样式(隐藏非活动图片,定位,过渡动画)→ JavaScript添加交互(事件监听器切换active类)→ 测试和调整。</think>### HTML+CSS简易轮播图实现教程 #### 一、基础结构搭建 ```html <!-- 轮播容器 --> <div class="slider"> <!-- 图片列表 --> <div class="slides"> <img src="image1.jpg" class="active"> <img src="image2.jpg"> <img src="image3.jpg"> </div> <!-- 导航圆点 --> <div class="dots"> <span class="active"></span> <span></span> <span></span> </div> </div> ``` #### 二、添加CSS样式 ```css .slider { position: relative; width: 600px; height: 400px; overflow: hidden; /* 隐藏溢出内容 */ } .slides img { position: absolute; width: 100%; height: 100%; opacity: 0; /* 默认隐藏 */ transition: opacity 0.5s ease; /* 淡入淡出效果 */ } .slides img.active { opacity: 1; /* 显示当前图片 */ } .dots { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; } .dots span { width: 12px; height: 12px; border-radius: 50%; background: rgba(255,255,255,0.5); cursor: pointer; } .dots span.active { background: white; } ``` #### 三、JavaScript交互实现 ```javascript let current = 0; const slides = document.querySelectorAll(&#39;.slides img&#39;); const dots = document.querySelectorAll(&#39;.dots span&#39;); // 更新显示状态 function updateSlide(index) { slides.forEach(img => img.classList.remove(&#39;active&#39;)); dots.forEach(dot => dot.classList.remove(&#39;active&#39;)); current = (index + slides.length) % slides.length; // 循环处理 slides[current].classList.add(&#39;active&#39;); dots[current].classList.add(&#39;active&#39;); } // 圆点点击事件 dots.forEach((dot, index) => { dot.addEventListener(&#39;click&#39;, () => updateSlide(index)); }); // 自动轮播(可选) setInterval(() => updateSlide(current + 1), 3000); ``` #### 四、实现效果说明 1. 使用`position: absolute`使图片层叠 2. 通过`opacity`过渡实现淡入淡出效果[^1] 3. 导航圆点使用Flex布局水平居中[^2] 4. JavaScript控制当前显示索引 5. 自动轮播通过定时器实现(可注释关闭)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值