CSS实现广告自动轮播

实现原理

该广告轮播功能的实现主要依靠HTML和CSS。HTML负责搭建轮播框架,而CSS则控制样式和动画效果。通过CSS中的关键帧动画(Keyframes),我们可以定义图片在容器内的滚动效果,从而实现轮播功能。

HTML结构

首先,我们需要一个包裹所有轮播图片的容器,并在其中放置各个广告图片:

html 复制代码
<div class="slider">
    <div class="container">
        <img src="images/b1.jpg" alt="">
        <img src="images/b2.jpg" alt="">
        <img src="images/b3.png" alt="">
        <img src="images/b4.jpg" alt="">
    </div>
</div>

CSS样式

接下来需要再css中设置轮播容器和图片的样式。 .slider 是整个轮播区域,宽度被设定为单张图片的宽度 (1226px),高度为 460px,并且居中显示。.slider .container 的宽度则是单张图片宽度乘以图片数量 (4 * 1226px = 4904px),保证了可以容纳4张图片连续排列。因为这里有四张图片,所以 在0%时,不平移;在25%时,向左平移一张图片的宽度;在50%时,向左平移两张图片的宽度;在75%时,向左平移三张图片的宽度;在100%时,回到初始位置,开始新一轮的循环。

css 复制代码
.slider {
    height: 460px;
    width: 1226px;
    margin: 0 auto;
    overflow: hidden;
    position: relative;
}

.slider .container {
    width: 4904px; /* 图片宽度 * 图片数量 */
    height: 460px;
    overflow: hidden;
    position: absolute;
    display: flex;
    animation: run 10s linear infinite;
}

.slider img {
    height: 100%;
    width: 1226px;
    display: block;
    margin: 0 auto;
}

@keyframes run {
    0% {
        transform: translateX(0);
    }
    25% {
        transform: translateX(-1226px);
    }
    50% {
        transform: translateX(-2452px);
    }
    75% {
        transform: translateX(-3678px);
    }
    100% {
        transform: translateX(0);
    }
}

下面是模仿小米商城的一个效果

相关推荐
国产化创客17 分钟前
ESP32+Web实现智能气象站
前端·物联网·智能家居·智能硬件
coderYYY1 小时前
VSCode终端启动报错
前端·ide·vscode·npm·编辑器
tod1132 小时前
Redis 数据类型与 C++ 客户端实践指南(redis-plus-plus)
前端·c++·redis·bootstrap·html
Sylvia33.2 小时前
火星数据:棒球数据API
java·前端·人工智能
weixin199701080162 小时前
1688商品详情页前端性能优化实战
前端·性能优化
DEMO派2 小时前
前端常用XSS攻击演示与防御方案解析
前端·xss
问今域中3 小时前
Vue的computed用法解析
前端·javascript·vue.js
扶苏10023 小时前
详解Vue3的provide和inject
前端·javascript·vue.js
武帝为此3 小时前
【Shell 函数库介绍】
前端·chrome
yuki_uix4 小时前
GraphQL 重塑:从 API 语言到 AI 时代的"逻辑神经系统"
前端·graphql