css—轮播图实现

一、背景

        最近和朋友在一起讨论的时候,我们提出了这样的一个提问,难道轮播图的效果只能通过js来实现吗?经过我们的一系列的争论,发现了这是可以通过纯css来实现这一效果的,CSS轮播图也是一种常见的网页展示方式,可以通过CSS样式来实现图片的切换效果。它不依赖于JavaScript,运行速度较快,并且具有较好的兼容性。那么今天一如既往的来一起来探讨一下如何去实现这一效果。

二、思路解析

        这个效果并不是想想中的那么难,在这里我们需要使用到的有css中的属性也有css3中的属性,如果来阅读的小伙伴没有接触css3,也不用急,我会在接下来的一篇文章中详细介绍一下,这里使用到的css3的属性。

思路:

        大家应该知道在很早之前的胶片电影的播放形式,我们这里的一个录播效果和胶片电影的思路是大同小异的,那么究竟是什么呢。

        1、首先我们需要创建一个让用户观看轮播图的视口,也就是我们可以看到的部分;

        2、既然有可以看到的部分,那就一定有不可以让用户看到的部分,所以超出的部分怎么办呢?这里我不做解释,留些思考的空间你们来想一下呢。

        3、那么如何让这些图片动起来呢,这里就用到了css3中的属性,那就是动画属性,之后我会进行解释。

        这就是基本的实现思路了。话不多说,直接进入代码实现阶段。

三、拆解分析阶段

注意:接下来的代码结构为了更好的让小伙伴们串联起来,所以采用了代码迭代的方式来讲解,在最后会添加代码的总体结构和css样式。

第一步我们就来创建我们的视口部分,在这里我们使用了div.wrap_out作为视口展示。

<div class="wrap_out"></div>
.wrap_out {width: 500px;height: 300px;margin: 300px auto;border: 2px solid #f00;}

第二步我们需要来创建存放我们所有需要展示的内容的容器,这里我们使用ul来充当这一个容器,在这里我们展示5张图片,所以这里我们需要给ul这个容器设置宽为25oopx,高度和视口高度一致。

<div class="wrap_out"><ul class="wrap"></ul></div>
  .wrap {width: 2500px;height: 300px;}

第三步,我们来创建存放每个内容的盒子,这里由于我们使用的是ul来融合这一部分,所以我们只要使用li来定义存放内容的盒子就可以。在这里我不使用图片讲解,我就直接使用不同的文字进行区分。

<div class="wrap_out"><ul class="wrap"><li>FIRST</li><li>SECOND</li><li>THIRD</li><li>FOURTH</li><li>FIFTH</li></ul></div>
.wrap > li {width: 500px;height: 300px;background-color: #f90;}

如果只这样写,那是肯定无法实现最终需要的效果的,所以现在我们需要让所有的盒子横向排列成一行,以方便之后的移动 。只需要在之前的ul中更新为以下代码

   .wrap {width: 2500px;height: 300px;display: flex;}

 增加完之后就会发现已经成为了我们初步想要实现的结果。

接下来就是把超出红色边框视口的部分隐藏。如下图:

      .wrap_out {width: 500px;height: 300px;margin: 300px auto;border: 2px solid #f00;overflow: hidden;}

现在我们视口中只能看到第一张图,其他的图片都在第一张的后边,那么接下来就不难想到了,只要让ul这个大盒子自己无限次的移动就可以了。 

所以接下来我们需要来定制动画的规则,让他们动起来。

@keyframes wrap_animation {0% {transform: translate(0);}10% {transform: translate(0);}25% {transform: translate(-500px);}35% {transform: translate(-500px);}50% {transform: translate(-1000px);}60% {transform: translate(-1000px);}75% {transform: translate(-1500px);}85% {transform: translate(-1500px);}90% {transform: translate(-2000px);}100% {transform: translate(-2000px);}}

 然后我们需要在需要设置动画的元素中引用我们已经定制好的规则。

.wrap {width: 2500px;height: 300px;display: flex;animation: wrap_animation 10s infinite linear;}

 注意:这里需要注意不要将动画添加错元素

 添加好之后就会发现静态的页面动起来了

但是会发现一个问题,就是在最后一张图之后会有一个白色的置空区域,那么如何解决呢,又是因为什么呢?

有空白的原因是应为我们的 transform: translate()属性是以左边边框为基准点进行平移的,所以当我们移动到-2500px的时候就刚好会漏出那张白色的空白区域,所以我们只需要在最后添加一张和第一张图一样的区域,就可以实现轮播效果。 

<ul class="wrap"><li style="background-color: #f00">FIRST</li><li style="background-color: #0f0">SECOND</li><li style="background-color: #00f">THIRD</li><li style="background-color: pink">FOURTH</li><li style="background-color: purple">FIFTH</li><li style="background-color: #f00">FIRST</li></ul>

这样我们的轮播图效果就完成了。

四、代码总览

1、html部分

<body><div class="box"><div class="wrap_out"><ul class="wrap"><li style="background-color: #f00">FIRST</li><li style="background-color: #0f0">SECOND</li><li style="background-color: #00f">THIRD</li><li style="background-color: pink">FOURTH</li><li style="background-color: purple">FIFTH</li><li style="background-color: #f00">FIRST</li></ul></div></div></body>

 2、CSS部分

<style>* {margin: 0;padding: 0;}html {/* overflow-x: hidden; */}ul {list-style: none;}.box {width: 100vw;height: 100vh;display: flex;}.wrap_out {width: 500px;height: 300px;margin: 300px auto;border: 2px solid #f00;overflow: hidden;}.wrap {width: 3000px;height: 300px;display: flex;animation: wrap_animation 10s infinite linear;}.wrap > li {width: 500px;height: 300px;}@keyframes wrap_animation {0% {transform: translate(0);}10% {transform: translate(0);}25% {transform: translate(-500px);}35% {transform: translate(-500px);}50% {transform: translate(-1000px);}60% {transform: translate(-1000px);}75% {transform: translate(-1500px);}85% {transform: translate(-1500px);}90% {transform: translate(-2000px);}100% {transform: translate(-2000px);}}</style>

五、结语

        感谢大家的耐心阅读,希望这篇文章能给您带来一些启发和帮助。如果您有任何疑问或建议,请随时在评论区留言,我会尽快回复。今天的分享就到这里了,如果您觉得这篇文章还不错,请点赞、分享给更多的朋友吧!同时,也欢迎关注我的博客,获取更多精彩内容。

    补充: css动画可以看这个文章,同样也是我整理的一些动画知识。

css—动画-CSDN博客本文主要讲解动画的基本使用。定义动画规则以及一些动画属性的使用。https://blog.csdn.net/m0_64387122/article/details/144066216?sharetype=blogdetail&sharerId=144066216&sharerefer=PC&sharesource=m0_64387122&spm=1011.2480.3001.8118

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/62662.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nacos安装部署

nacos安装部署 1.安装nacos 1.安装nacos nacos的安装很简单下载后解压启动即可&#xff0c;但是在启动前请确保jdk环境正常&#xff1b; 1.首先我们要下载nacos安装包&#xff1a;可以到官网下载&#xff0c;注意我这里使用的是2.1.0版本&#xff1b; 2.下载完成后&#xff0…

tomcat 8.5.35安装及配置

安装包地址&#xff1a; 1.Index of /dist/tomcat/tomcat-8/v8.5.35/binhttps://archive.apache.org/dist/tomcat/tomcat-8/v8.5.35/bin/ 2.通过网盘分享的文件&#xff1a;tomcat 链接: https://pan.baidu.com/s/1z9bD4rIuIRvzQ4okm3iRzw?pwdp24p 提取码: p24p 3.通过官网…

YOLO系列论文综述(从YOLOv1到YOLOv11)【第12篇:YOLOv9——可编程梯度信息(PGI)+广义高效层聚合网络(GELAN)】

YOLOv9 1 摘要2 改进点3 网络架构 YOLO系列博文&#xff1a; 【第1篇&#xff1a;概述物体检测算法发展史、YOLO应用领域、评价指标和NMS】【第2篇&#xff1a;YOLO系列论文、代码和主要优缺点汇总】【第3篇&#xff1a;YOLOv1——YOLO的开山之作】【第4篇&#xff1a;YOLOv2—…

机器学习提高电子病历主要诊断编码正确率的路径分析

摘要 本研究探讨机器学习在强化病历书写质量和提高主要诊断编码正确率方面的应用。介绍了基于机器学习的病历质量分析方法、AI病历质控应用、智能预问诊系统和诊室听译机器人等在病历书写质量提升中的作用&#xff0c;以及基于机器学习的ICD智能诊断编码方法和重症病人ICD自动…

鸿蒙征文|鸿蒙技术分享:使用到的开发框架和技术概览

目录 每日一句正能量前言正文1. 开发环境搭建关键技术&#xff1a;2. 用户界面开发关键技术&#xff1a;3. 应用逻辑开发关键技术&#xff1a;4. 应用测试关键技术&#xff1a;5. 应用签名和打包关键技术&#xff1a;6. 上架流程关键技术&#xff1a;7. 后续维护和更新关键技术…

C++类中多线程的编码方式

问题 在C++代码中,一般的代码是需要封装在类里面,比如对象,方法等。否则就不能很好的利用C++面向对象的能力了。 但是这个方式在处理线程时会碰到一个问题。 考虑下面一个简单的场景: class demoC { public:std::thread t;int x;void threadFunc(){std::cout<<x&…

Android开发仿qq详情下拉头像变大

Android开发仿qq详情下拉头像变大 个人详情界面&#xff0c;很多都有下拉头像变大的效果&#xff0c;其实我觉得这效果还不如点击头像看大图呢 一、思路&#xff1a; 自定义ScrollView 二、效果图&#xff1a; 看视频更直观点&#xff1a; Android开发教程案例分享-仿qq详情…

深入解析下oracle date底层存储方式

之前我们介绍了varchar2和char的数据库底层存储格式&#xff0c;今天我们介绍下date类型的数据存储格式&#xff0c;并通过测试程序快速获取一个日期。 一、环境搭建 1.1&#xff0c;创建表 我们还是创建一个测试表t_code&#xff0c;并插入数据&#xff1a; 1.2&#xff0c;…

golang版本管理工具:scoop使用

安装 Scoophttps://scoop.sh/根据官方文档安装。 第一步&#xff1a;打开PowerShell。(注意不要使用管理员方式打开&#xff0c;否则在执行安装Scoop的过程中&#xff0c;会报错。) 第二步&#xff1a;切到C盘根目录下。 第三步&#xff1a; Set-ExecutionPolicy -Executi…

时装购物系统

私信我获取源码和万字论文&#xff0c;制作不易&#xff0c;感谢点赞支持。 摘 要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;时装购物系统当然也不能排除在外。时装购物…

架构04-透明多级分流系统

零、文章目录 架构04-透明多级分流系统 1、透明多级分流系统 &#xff08;1&#xff09;概述 **定义&#xff1a;**透明多级分流系统是指在用户请求从客户端发出到最终查询或修改数据库信息的过程中&#xff0c;通过多个技术部件对流量进行合理分配&#xff0c;以提高系统的…

【AI】数据,算力,算法和应用(3)

三、算法 算法这个词&#xff0c;我们都不陌生。 从接触计算机&#xff0c;就知道有“算法”这样一个神秘的名词存在。象征着专业、权威、神秘、高难等等。 算法是一组有序的解决问题的规则和指令&#xff0c;用于解决特定问题的一系列步骤。算法可以被看作是解决问题的方法…

YOLO系列论文综述(从YOLOv1到YOLOv11)【第14篇:YOLOv11——在速度和准确性方面具有无与伦比的性能】

YOLOv11 1 摘要2 改进点3 模型性能4 模型架构 YOLO系列博文&#xff1a; 【第1篇&#xff1a;概述物体检测算法发展史、YOLO应用领域、评价指标和NMS】【第2篇&#xff1a;YOLO系列论文、代码和主要优缺点汇总】【第3篇&#xff1a;YOLOv1——YOLO的开山之作】【第4篇&#xff…

最短路径(Floyd-Warshall、Dijkstra、Bellman-Ford)

图的遍历&#xff0c;通过算法优雅实现。 上次使用遍历的方法求得最短路径&#xff08;图的遍历。-CSDN博客&#xff09;&#xff0c;这样虽然可以解决问题&#xff0c;但还是不够优雅&#xff0c;有一些弊端&#xff0c;时间复杂度和空间复杂度都比较高。本博客主要描述三种求…

一些优秀的布隆过滤器介绍

&#x1f680; 博主介绍&#xff1a;大家好&#xff0c;我是无休居士&#xff01;一枚任职于一线Top3互联网大厂的Java开发工程师&#xff01; &#x1f680; &#x1f31f; 在这里&#xff0c;你将找到通往Java技术大门的钥匙。作为一个爱敲代码技术人&#xff0c;我不仅热衷…

YOLOv8模型pytorch格式转为onnx格式

一、YOLOv8的Pytorch网络结构 model DetectionModel((model): Sequential((0): Conv((conv): Conv2d(3, 64, kernel_size(3, 3), stride(2, 2), padding(1, 1))(act): SiLU(inplaceTrue))(1): Conv((conv): Conv2d(64, 128, kernel_size(3, 3), stride(2, 2), padding(1, 1))(a…

论文解读:Reward criteria impact on the performance ofreinforcement learning...

Reward criteria impact on the performance ofreinforcement learning agent for autonomous navigation 译文&#xff1a; 奖励准则对自主导航强化学习agent性能的影响 摘要&#xff1a; 在强化学习中&#xff0c;主体在环境中的每个时间步采取行动&#xff08;遵循策略&…

glog在vs2022 hello world中使用

准备工作 设置dns为阿里云dns 223.5.5.5&#xff0c;下载cmake&#xff0c;vs2022&#xff0c;git git clone https://github.com/google/glog.git cd glog mkdir build cd build cmake .. 拷贝文件 新建hello world并设置 设置预处理器增加GLOG_USE_GLOG_EXPORT;GLOG_NO_AB…

搜索二维矩阵 II(java)

题目描述 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&#xff1a; 每行的元素从左到右升序排列。每列的元素从上到下升序排列。 代码思路&#xff1a; 用暴力算法&#xff1a; class Solution {public boolean searchMatrix(…

基于vite创建的react18项目的单元测试

题外话 最近一个小伙伴进了字节外包&#xff0c;第一个活就是让他写一个单元测试。 嗯&#xff0c;说实话&#xff0c;在今天之前我只知道一些理论&#xff0c;但是并没有实操过&#xff0c;于是我就试验了一下。 通过查询资料&#xff0c;大拿们基本都说基于vite的项目&…