CSS3 animation(动画) 属性与涟漪效果的实现

2023-11-29 11:30

本文主要是介绍CSS3 animation(动画) 属性与涟漪效果的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、语法

animation: name duration timing-function delay iteration-count direction fill-mode play-state;

属性简介:

说明
animation-name指定要绑定到选择器的关键帧的名称
animation-duration动画指定需要多少秒或毫秒完成
animation-timing-function设置动画将如何完成一个周期
animation-delay设置动画在启动前的延迟间隔,单位可以是秒(s)或毫秒(ms),可以是负值,若为-2s则立即开始但是(第一次)会直接跳到动画2s处
animation-iteration-count定义动画的播放次数
animation-direction指定是否应该轮流反向播放动画
animation-fill-mode规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式
animation-play-state指定动画是否正在运行或已暂停
initial设置属性为其默认值
inherit从父元素继承属性

二、各属性详细介绍

1.animation-name

语法:animation-name: keyframename|none;

说明
keyframename指定要绑定到选择器的关键帧的名称
none指定有没有动画(可用于覆盖从级联的动画)

补充: @keyframes 规则是创建动画。 @keyframes 规则内指定一个 CSS 样式和动画将逐步从目前的样式更改为新的样式。
例如:将背景色由红变黄

@-webkit-keyframes myfirst /* Safari 与 Chrome */
{from {background: red;}to {background: yellow;}
}

2.animation-duration

说明
time指定动画播放完成花费的时间。默认值为 0,意味着没有动画效果。

3.animation-timing-function

animation-timing-function使用的数学函数,称为三次贝塞尔曲线,速度曲线。使用此函数,您可以使用您自己的值,或使用预先定义的值之一:

描述对应cubic-bezier 函数
linear动画从头到尾的速度是相同的cubic-bezier(0,0,1,1)
ease(默认)动画以低速开始,然后加快,在结束前变慢cubic-bezier(0.25,0.1,0.25,1)
ease-in动画以低速开始cubic-bezier(0.42,0,1,1)
ease-out动画以低速结束cubic-bezier(0,0,0.58,1)
ease-in-out动画以低速开始和结束cubic-bezier(0.42,0,0.58,1)
cubic-bezier(n,n,n,n)在 cubic-bezier 函数中自己的值,可能的值是从 0 到 1 的数值。

对于同一个曲线,cubic-bezier函数的参数可能不同,如linear曲线的cubic-bezier的参数可以写为(0.5,0.5,0.5,0.5)
想要多了解了解cubic-bezier的伙伴可以移步css中animation属性animation-timing-function知识点以及属性值steps()详解,在这里就不展开说明了。

4.animation-delay

定义动画何时开始。单位可以是毫秒(ms)或秒(s),默认是0,允许负值,-2s 使动画马上开始,但跳过 2 秒进入动画。注意:如果是无限循环动画,则只有第一次会被跳过2s。

5.animation-iteration-count

定义动画的播放次数。值可以是n或infinite(无数次)

6.animation-direction

定义是否应该轮流反向播放动画。值为normal或alternate,如果 animation-direction 值是 “alternate”,则动画会在奇数次数(1、3、5 等等)正常播放,而在偶数次数(2、4、6 等等)向后播放。说白了就是一次正一次反……

7.animation-fill-mode

规定动画在播放之前或之后,其动画效果是否可见,其属性值是由逗号分隔的一个或多个填充模式关键词(none | forwards | backwards | both)。

描述
none不改变默认行为
forwards当动画完成后,保持最后一个属性值(在最后一个关键帧中定义)
backwards在 animation-delay 所指定的一段时间内,在动画显示之前,应用开始属性值(在第一个关键帧中定义)
both向前和向后填充模式都被应用

想要多了解了解animation-fill-mode的同学可以移步animation-fill-mode,这里有示例。

8.animation-play-state

规定动画正在运行还是暂停,可以在 JavaScript 中使用该属性,这样就能在播放过程中暂停动画(object.style.animationPlayState=“paused”)。

三、示例:用css实现涟漪效果

这里直接用animation来实现。
涟漪肯定不能只有一个圈同时存在,所以我设置了3个div嵌套。用flex布局实现水平垂直居中。然后设置动画完成时间为1.5s,速度曲线为linear,无限循环。
css部分:

body{background-color: rgb(62, 178, 224);}.content{display: flex;justify-content: center;align-items:center;width: 100px;  /*width和height必须设置,不然就不是从中间向外扩散了*/height: 100px;margin: 175px auto;}.wave{display: flex;justify-content: center;align-items:center;border: white 1px solid;}.wave1 {animation:wave1 1.5s linear infinite;}.wave2{animation:wave2 1.5s linear infinite;}.wave3{animation:wave3 1.5s linear infinite;}@keyframes wave3{from{width: 2px;height: 2px;border-radius: 1px;}to{width: 20px;height: 20px;border-radius: 10px;}} @keyframes wave2{from{width: 20px;height: 20px;border-radius: 10px;}to{width: 50px;height: 50px;border-radius: 25px;}} @keyframes wave1{from{width: 50px;height: 50px;border-radius: 25px;}to{width: 100px;height: 100px;border-radius: 50px;}} 

html部分:

<body><div class="content"><div class="wave wave1"><div class="wave wave2"><div class="wave wave3"></div></div></div></div>
</body>

附上效果图,感兴趣的小伙伴儿可以自己copy一下,改成自己心中的效果~
涟漪效果图
先写这么多,以后有好玩的css动画效果,我会再在这里更新。

这篇关于CSS3 animation(动画) 属性与涟漪效果的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/432645

相关文章

Python实现Word转PDF全攻略(从入门到实战)

《Python实现Word转PDF全攻略(从入门到实战)》在数字化办公场景中,Word文档的跨平台兼容性始终是个难题,而PDF格式凭借所见即所得的特性,已成为文档分发和归档的标准格式,下面小编就来和大... 目录一、为什么需要python处理Word转PDF?二、主流转换方案对比三、五套实战方案详解方案1:

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的