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);
    }
}

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

相关推荐
敲敲了个代码4 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
dly_blog5 小时前
Vue 响应式陷阱与解决方案(第19节)
前端·javascript·vue.js
消失的旧时光-19436 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
console.log('npc')6 小时前
Table,vue3在父组件调用子组件columns列的方法展示弹窗文件预览效果
前端·javascript·vue.js
用户47949283569156 小时前
React Hooks 的“天条”:为啥绝对不能写在 if 语句里?
前端·react.js
我命由我123456 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法
用户47949283569157 小时前
给客户做私有化部署,我是如何优雅搞定 NPM 依赖管理的?
前端·后端·程序员
C_心欲无痕7 小时前
vue3 - markRaw标记为非响应式对象
前端·javascript·vue.js
qingyun9897 小时前
深度优先遍历:JavaScript递归查找树形数据结构中的节点标签
前端·javascript·数据结构
熬夜敲代码的小N7 小时前
Vue (Official)重磅更新!Vue Language Tools 3.2功能一览!
前端·javascript·vue.js