使用CSS实现简单的图片切换(轮播图)

使用CSS实现简单的图片切换(轮播图)

预览图如下:


在这里插入图片描述

一:首先创建基本布局

1:创建一个div容器 ,里面的ul与ol标签分别对应轮播图片和下方圆点;

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="css/style.css">
    <title>css轮播</title>
</head>

<body>
    <div class="container">
        <ul>
            <li><img src="./img/1.jpg" alt=""></li>
            <li><img src="./img/2.jpg" alt=""></li>
            <li><img src="./img/3.jpg" alt=""></li>
        </ul>
        <ol>
            <li></li>
            <li></li>
            <li></li>
        </ol>
    </div>
</body>

</html>

二:添加CSS样式

1:为图片与圆点添加相应样式,使其正常显示;

*{padding: 0;margin: 0;box-sizing: border-box;}
li{
    list-style: none;
    float: left;
}
ul img{
    width: 960px;
    height: auto;
    
}
.container{
    width: 960px;//容器大小要和图片大小保持一致。
    height: 544px;
    margin: 50px auto 0;
    overflow: hidden;
    position: relative;
    border: 1px solid black;
}
ol{
    position: absolute;
    bottom: 0;
    left: 50%;
    padding: 10px;
    margin-left: -50px;
    z-index: 999;

}
ol li{
    width: 25px;
    height: 25px;
    background-color: #fff;
    border: 1px solid red;
    border-radius: 50%;
    margin: 0 10px;
}

标题2:为图片和圆点添加动画样式;



.container ul{
       animation:Yui 3s cubic-bezier(0, 1, 0, 1) 1s infinite ;
       width: 400%;

}
@keyframes Yui{
      0% {
        transform: translateX(0px);
      }
      33% {
        transform: translateX(-960px);
      }
      66% {
        transform: translateX(-1920px);
      }
      100% {
        transform: translateX(0px);
      }
      
}
ol li {
  animation:focus 3s linear infinite ;//时间要和图片保持一致
  }
  ol li:nth-child(1) {
    animation-delay: 0s;
  }
  ol li:nth-child(2) {
    animation-delay: 1s;
  }
  ol li:nth-child(3) {
    animation-delay: 2s;
  }
 
  @keyframes focus {
    0% { 
      background-color: #000;
    }
    20% {
      background-color: #000;
    }
    30% {
      background-color: #fff;
    }
  }

转载请注明出处

  • 102
    点赞
  • 714
    收藏
    觉得还不错? 一键收藏
  • 23
    评论
HTMLCSS可以结合使用,再加上JavaScript(如果需要动态效果)来实现图片轮播功能。以下是一个基本的步骤和示例代码: 1. **HTML结构**: ```html <div class="slideshow-container"> <div class="slide"> <img src="image1.jpg" alt="Image 1"> </div> <div class="slide"> <img src="image2.jpg" alt="Image 2"> </div> <!-- 更多图片 --> </div> ``` 2. **CSS样式**: ```css .slideshow-container { position: relative; width: 100%; height: 400px; overflow: hidden; } .slide { position: absolute; display: none; } .slide.active { display: block; } ``` 3. **JavaScript (可选, CSS3动画实现轮播)**: 无JavaScript的情况下,可以通过CSS3的`transition`或`animation`实现简单的轮播效果。例如,使用关键帧动画: ```css .slide { transition: transform 2s ease-in-out; } .slide.active { transform: translateX(0); } .slide.next { transform: translateX(-100%); } /* 添加按钮切换事件 */ <button onclick="changeSlide(-1)">Prev</button> <button onclick="changeSlide(1)">Next</button> ``` 4. **JavaScript 动态切换图片**: ```javascript function changeSlide(direction) { var slides = document.querySelectorAll('.slide'); var currentSlide = slides[slides.length * direction]; // 根据方向获取当前显示的图片 // 切换显示状态 currentSlide.classList.remove('active'); currentSlide.classList.add('next'); // 获取下一张/上一张并切换 var nextSlide = slides[slides.length * direction + 1]; if (nextSlide) { nextSlide.classList.remove('next'); nextSlide.classList.add('active'); } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值