用CSS来做一个动画案例

news2024/9/29 11:25:39

今天来做这么一个案例

 添加一个动画实现上下渐变滚动的效果

首先还是我们HTML部分,一个大盒子装着五个子元素

下面别在意,之前写的时候看到有个网站有这么个注解我就复制了下来哈哈哈

<div class="loader">
			<div class="slider" style="--i:0">
			</div>
			<div class="slider" style="--i:1">
			</div>
			<div class="slider" style="--i:2">
			</div>
			<div class="slider" style="--i:3">
			</div>
			<div class="slider" style="--i:4"> 
			</div>
		</div>
		<!-- keywords fixed by:lxl passed by:PTB ↑↑↑关键词也太多了,已经导致被k站了,修改了。-->
		    <!-- wogiao 你没事为啥老来改网站?客户端bug后端内存溢出问题解决了?主机加速适配了?-->
		    <!-- 管你屁事 -->
		    <!-- keywords fixed by:wogaio passed by:PTB 修改关键词,现在应该不会被Ai误判了。--><!--new by:yjj 2023/1/25 wogiao那哥们骂我,**的,他的 经典 我给他保留了,美其名曰:节目效果-->
		
		<!-- 写网页前端的哥们,老子cnm,代码全部不格式化,上面喊你改也不改,老子开发客户端的跑来给你手动格式化,你是真特么nt,祝你早日滚蛋!下面写的sb滚动把图床快干废了,一天跑了3t流量你是真的牛逼,老子直接给你删了,都不想给你注释化,滚! by:wogiao 2022年11月25日 -->
		<!-- 
		           ▃▆█▇▄▖
		      ▟◤▖   ◥█▎
		     ◢◤  ▐     ▐▉
		  ▗◤   ▂ ▗▖  ▕█▎
		 ◤ ▗▅▖◥▄ ▀◣  █▊
		▐ ▕▎◥▖◣◤    ◢██
		█◣ ◥▅█▀    ▐██◤
		▐█▙▂        ◢██◤
		◥██◣    ◢▄◤
		   ▀██▅▇▀
		哲学♂♂ 114514-->

第一步首先呢我们得让我们的大盒子设置一个弹性布局

让父元素水平垂直居中

.loader{
                display: flex;
                align-items: center;
                justify-content: center;

第二步我们来设置子元素

设置一个隐藏多余的样式,然后我们设置这个盒子宽高大小还有内外边距还有边框弧度加上内阴影弧度,最后设置一个相对定位,使他的子元素设置为据对定位

.slider{
                overflow: hidden;
                background-color: whitesmoke;
                border: 1px solid rgba(128,128,0.276);
                height: 80px;
                width: 20px;
                margin: 0 15px;
                border-radius: 30px;
                box-shadow: inset -5px -5px 10px #0000001a,
                inset -5px -5px 10px #0000001a;
                position: relative;
                
            }

第三步设置子元素的伪元素

content必不可少,因为这是一个主体,没有这个就没有内容,然后我们在继续设置绝对定位,置于左上角,然后设置宽高颜色,最后我们添加一个过渡方式,然后再下面我们来加动画

.slider::before{
                content: "";
                position: absolute;
                top: 0;
                left: 0;
                height: 80px;
                width: 20px;
                background: #2697f3;
                animation: alternate_2 2.5s ease-in-out infinite;
            }

第四步添加动画

@keyframes alternate_2{
                from{
                    transform: translateY(80px);
                    filter: hue-rotate(0deg);
                }
                50%{
                    transform: translateY(20px);
                }
                to{
                    transform: translateY(80px);
                    filter: hue-rotate(360deg);
                }
            }

from:开始的意思,然后沿着y轴上身80px

然后到五十的时候有沿着Y又下来20px

到百分比也就是to的时候就是还原,这里的filter我们是给他添加一个过渡的颜色

然后呢这段代码创建了五个 div 元素,每个元素带有类名为 "slider"。但是它们之间的区别在于其内联样式中的变量 "--i" 的值。因此,它们将被视为一个由五个相关但独立的滑块组成的组。

变量 "--i" 用于设置当前滑块的索引(从 0 开始)。这意味着第一个 div 元素将显示第一张图片,第二个将显示第二张图片,以此类推。

当使用 CSS 样式表中的其他规则来定义每个 ".slider" 类时,可以使用变量 "--i" 来针对每个滑块应用不同的样式。

<div class="slider" style="--i:0">
            </div>
            <div class="slider" style="--i:1">
            </div>
            <div class="slider" style="--i:2">
            </div>
            <div class="slider" style="--i:3">
            </div>
            <div class="slider" style="--i:4"> 
            </div>

最后代码使用 CSS 伪元素 ::before 为每个 .slider 元素添加一个动画效果。

其中 animation 属性指定了使用名为 alternate_2 的动画,持续时间为 2.5 秒,缓动函数为 ease-in-out,而且该动画无限循环。

而 animation-delay 属性则是设置延迟时间,它使用了变量 var(--i) 来决定每个元素的延迟时间。CSS 变量 --i 的值在每个 .slider 元素中都不同,因此每个元素的延迟时间也不同。其中通过计算 -0.5s*var(--i) 来设置每个滑块初始的动画延迟时间,这意味着第一个滑块不需要任何延迟,而后面的滑块则依次加上 0.5 秒的延迟时间。

.slider::before{
                animation: alternate_2 2.5s ease-in-out infinite;
                animation-delay: calc(-0.5s*var(--i));
            }
            

接下来是源码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			.loader{
				display: flex;
				align-items: center;
				justify-content: center;
				
			}
			.slider{
				overflow: hidden;
				background-color: whitesmoke;
				border: 1px solid rgba(128,128,0.276);
				height: 80px;
				width: 20px;
				margin: 0 15px;
				border-radius: 30px;
				box-shadow: inset -5px -5px 10px #0000001a,
				inset -5px -5px 10px #0000001a;
				position: relative;
				
			}
			.slider::before{
				content: "";
				position: absolute;
				top: 0;
				left: 0;
				height: 80px;
				width: 20px;
				background: #2697f3;
				animation: alternate_2 2.5s ease-in-out infinite;
			}
			@keyframes alternate_2{
				from{
					transform: translateY(80px);
					filter: hue-rotate(0deg);
				}
				50%{
					transform: translateY(20px);
				}
				to{
					transform: translateY(80px);
					filter: hue-rotate(360deg);
				}
			}
			.slider::before{
				animation: alternate_2 2.5s ease-in-out infinite;
				animation-delay: calc(-0.5s*var(--i));
			}
			
		</style>
	</head>
	<body>
		<div class="loader">
			<div class="slider" style="--i:0">
			</div>
			<div class="slider" style="--i:1">
			</div>
			<div class="slider" style="--i:2">
			</div>
			<div class="slider" style="--i:3">
			</div>
			<div class="slider" style="--i:4"> 
			</div>
		</div>
		<!-- keywords fixed by:lxl passed by:PTB ↑↑↑关键词也太多了,已经导致被k站了,修改了。-->
		    <!-- wogiao 你没事为啥老来改网站?客户端bug后端内存溢出问题解决了?主机加速适配了?-->
		    <!-- 管你屁事 -->
		    <!-- keywords fixed by:wogaio passed by:PTB 修改关键词,现在应该不会被Ai误判了。--><!--new by:yjj 2023/1/25 wogiao那哥们骂我,**的,他的 经典 我给他保留了,美其名曰:节目效果-->
		
		<!-- 写网页前端的哥们,老子cnm,代码全部不格式化,上面喊你改也不改,老子开发客户端的跑来给你手动格式化,你是真特么nt,祝你早日滚蛋!下面写的sb滚动把图床快干废了,一天跑了3t流量你是真的牛逼,老子直接给你删了,都不想给你注释化,滚! by:wogiao 2022年11月25日 -->
		<!-- 
		           ▃▆█▇▄▖
		      ▟◤▖   ◥█▎
		     ◢◤  ▐     ▐▉
		  ▗◤   ▂ ▗▖  ▕█▎
		 ◤ ▗▅▖◥▄ ▀◣  █▊
		▐ ▕▎◥▖◣◤    ◢██
		█◣ ◥▅█▀    ▐██◤
		▐█▙▂        ◢██◤
		◥██◣    ◢▄◤
		   ▀██▅▇▀
		哲学♂♂ 114514-->
	</body>
</html>

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

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

相关文章

【SpringCloud——Docker】

一、什么是Docker 二、Docker的基本操作 1、Docker操作镜像 镜像名称一般由两部分组成&#xff1a;[repository]:[tag] 在没有指定tag时&#xff0c;默认是latest&#xff0c;代表最新版本的镜像。 1.1、启动Docker服务 systemctl start docker1.2、查看Docker运行状态 syst…

34.序列中删除指定数组以及编写代码过程中遇到的问题

描述 有一个整数序列&#xff08;可能有重复的整数&#xff09;&#xff0c;现删除指定的某一个整数&#xff0c;输出删除指定数字之后的序列&#xff0c;序列中未被删除数字的前后位置没有发生改变。 数据范围&#xff1a;序列长度和序列中的值都满足 1≤&#xfffd;≤501≤…

外贸商城ERP系统-海外跨境电商平台【APP+小程序+PC多端同步商城系统】

外贸商城ERP跨境电商系统是帮助打开海外贸易&#xff0c;线上出海贸易的平台&#xff0c;欢迎名片探讨开发跨境电商系统&#xff0c;相互学习成长。 一、基础功能架构 跨境全球跨境贸易多语言无货源多国货币一键铺货后台采集多商户一件代发视频直播带货国JI化UI面板国际多类型…

音视频专栏-DTSPTS

一&#xff0c;网上很多人都在讲dts和pts&#xff0c;但是么有几个人把这个问题讲清楚&#xff0c;讲明白的&#xff0c;甚至很多做了很多年的音视频开发的人都搞不明白&#xff0c;今天我把原理图整理下&#xff0c;和大家一起学习&#xff0c;如有问题&#xff0c;欢迎批评指…

电子科技大学编译原理复习笔记(六):自上而下的语法分析

目录 前言 重点一览 引言 语法分析的功能 语法分析的分类 自上而下分析方法 回溯分析法 回溯分析法例子 方法 存在的问题 产生的原因 特点 解决缺陷 消除回溯&#xff08;重点&#xff09; 递归下降分析器 递归下降分析法 递归过程的构造 扩充BNF 改进的递…

MATLAB机器学习:分类、回归和聚类的算法实现和模型优化

第一章&#xff1a;引言 机器学习是当今IT领域最热门的话题之一&#xff0c;它为我们提供了解决复杂问题的新方法。MATLAB作为一种功能强大的编程语言和环境&#xff0c;提供了许多用于机器学习的工具和函数。本文将介绍MATLAB中常用的分类、回归和聚类算法的实现&#xff0c;…

chatgpt赋能python:Python中将数字倒序:一种简单的方法提高代码效率

Python中将数字倒序&#xff1a;一种简单的方法提高代码效率 数字倒序是Python中一种实用的操作。网站开发者和数据分析师通常需要对数字进行反转&#xff0c;以使其更容易阅读和理解。虽然有多种方法可以实现数字反转&#xff0c;但在绝大多数情况下&#xff0c;使用Python中…

详解浏览器渲染原理及流程

今天来分享一下浏览器的渲染原理及流程。 前言 先来看看 Chrome 浏览器的多进程架构&#xff1a; 通常&#xff0c;我们打包出来的 HTML、CSS、JavaScript 等文件&#xff0c;经过浏览器运行之后就会显示出页面&#xff0c;这个过程就是浏览器的渲染进程来操作实现的&#xf…

Windows安装和启动SSH服务

前言 作者在做项目时遇到需要从Windows系统远程传文件到Ubuntu系统&#xff0c;Ubuntu系统这边使用了gFTP的文件传输工具&#xff0c;但是远程Windows时发现老是连接不上&#xff0c;后面发现是Windows这边没有开启SSH服务。 找了一些文章&#xff0c;结合自己的操作把配置方法…

基于工业互联网的RV1126+AI安防单目/双目高清视觉分析计数仪方案

1产品简介 产品介绍 单目视觉分析计数器是信迈科技基于单目图像分析以及深度学习算法研发的一款区域统计计数器。它可以精确的识别监控区域内的物体&#xff0c;统计区域内停驻的人数/车辆等&#xff0c;也可以统计区域内进入以及离开人数。它可适用于公交车&#xff0c;大巴&…

旧衣回收小程序开发需具备哪些功能呢?

旧衣回收小程序开发需具备哪些功能呢&#xff1f; 1、预约回收。只要通过手机小程序进行预约就可以进行上门回收旧衣&#xff0c;平台会根据预约的时间安排就近回收员上门进行回收废旧衣服。或者用户直接在小程序上点击捐赠&#xff0c;填写地址信息、时间、联系方式等待…

Android进阶 View的工作原理:源码分析View的三大工作流程

Android进阶 View的工作原理&#xff1a;源码分析View的三大工作流程 导语 想象一下&#xff0c;如果我们要画画&#xff0c;把画画的流程拆分的话&#xff0c;那么应该分几个部分呢&#xff1f;一般来说&#xff0c;专业的画师会进行提前构图&#xff0c;然后再进行绘画最后上…

docker hub 访问不了,可以进行拉取和推送,但是不能进行注册登陆了,界面找不到了,大家一起讨论看看有什么好的解决办法。

1&#xff0c;docker hub 不能访问了 在 oschina 的地方找找了文章和原因&#xff1a; https://www.oschina.net/comment/news/241627 2&#xff0c;通过啥方式进行访问呢&#xff1f; 目前配置源还是可以正常的pull 和 push 的。 {"data-root": "/data/doc…

数据链路层:可靠传输

1.数据链路层&#xff1a;可靠传输 笔记来源&#xff1a; 湖科大教书匠&#xff1a;可靠传输的基本概念 湖科大教书匠&#xff1a;可靠传输的实现机制–停止等待协议SW 声明&#xff1a;该学习笔记来自湖科大教书匠&#xff0c;笔记仅做学习参考 1.1 可靠传输的基本概念 接收…

Rust 笔记:WebAssembly 的 JavaScript API

WebAssembly WebAssembly 的 JavaScript API 作者&#xff1a;李俊才 &#xff08;jcLee95&#xff09;&#xff1a;https://blog.csdn.net/qq_28550263?spm1001.2101.3001.5343 邮箱 &#xff1a;291148484163.com 本文地址&#xff1a;https://blog.csdn.net/qq_28550263/ar…

2023/5/29总结

abstract修饰符 抽象类就是当类和类之间有相同特征时&#xff0c;将这些共同的特征提取出来&#xff0c;形成的就是抽象类。 抽象类的特点&#xff1a; 抽象类和抽象方法必须使用abstract 关键字修饰&#xff1a;publicabstract class 类名 / public abstract void eat();抽象…

基于pytorch搭建多特征LSTM时间序列预测代码详细解读(附完整代码)

文章目录 LSTM时间序列预测数据获取与预处理模型构建训练与测试 LSTM时间序列预测 对于LSTM神经网络的概念想必大家也是熟练掌握了&#xff0c;所以本文章不涉及对LSTM概念的解读&#xff0c;仅解释如何使用pytorch使用LSTM进行时间序列预测&#xff0c;复原使用代码实现的全流…

【Python实战】Python采集小说文本内容

前言 今天,我们将采集某小说数据,通过这个案例,加深我们对正则表达式的理解。我们今天来通过使用正则表达式来获取我们想要的文本。 环境使用 python 3.9pycharm模块使用 requests模块介绍 requests requests是一个很实用的Python HTTP客户端库,爬虫和测试服务器响应…

MaxScript的Shape相关操作例子

MaxScript学习笔记目录 大家好&#xff0c;我是阿赵。之前有网友私信问了我一个相关的问题&#xff0c;我发现之前漏了MaxScript里面的Shape的内容&#xff0c;所以补一个例子&#xff0c;当做一个记录吧。 一、例子说明 这里做一个关于MaxScript读取二维形状(Shape)数据的例…

加盐加密——保障你的数据安全

目录 今日良言:理性和激情是生活不可或缺的调味品 一、加盐加密 1.普通密码的缺点 2.什么是加盐加密 3.加盐加密的过程 4.加盐加密的实现 今日良言:理性和激情是生活不可或缺的调味品 一、加盐加密 1.普通密码的缺点 在介绍加盐加密之前&#xff0c;先想想为什么普通密…