推荐10个常用的CSS动画库
网站地址:animate.style/
网站描述:齐全的CSS3动画库
想必这个不用介绍,大部分人都知道了。Animate CSS 可能是最著名的动画库之一。这里简要介绍一下它的用法:
1. 用法 首先,必须在总需要动画元素上添加类animated ,然后是动画的名字。
<div class="animated slideInLeft"></div>
如果我们想让动画一直持续,可以添加infinite类。
通过 js 来添加动画:
document.querySelector('.my-element').classList.add('animated', 'slideInLeft')
通过 JQ 来添加动画:
$(".my-element").addClass("animated slideInLeft")
2. 其它功能 Animate CSS提供了一些基本的类来控制动画的延迟和速度。
delay
可以添加 delay 类来延迟动画的播放。
<div class="animated slideInLeft delay-{1-5}"><div>
speed
我们还可以通过添加如下列出的类之一来控制动画速度。
<div class="animated slideInLeft slow|slower|fast|faster"><div>
网站地址:animista.net/ 网站描述:在线生成 css 动画
Animista是一个在线动画生成器,同时也是一个动画库,它为我们提供了以下功能
1. 选择不同的动画 我们可以选择想要的动画类型(例如entrance/exist),除了可以选择某个动画(例如,scale-in)外,甚至还可以为该动画选择不同的展示效果(例如: scale-in-right)。
2. 定制 Animista还提供了一个功能,允许我们定制动画的某些部分,比如
duration delay direction 更好的是,可以选择要设置动画的对象
3. 生成css代码 选择适合自己需要的动画后,我们可以直接从网站上获取代码,甚者可以进行压缩:
4. 下载代码 另一个好用的功能是,可以把自己收藏自己喜欢的动画,然后一起下载下来, 或者,我们也可以选择将这些动画的代码复制到一起。
网站地址: vivify.mkcreative.cz/
网站描述: 一个更加丰富css动画库
Vivify 是一个动画库,可以看作是Animate CSS的增强版。它们的工作方式完全相同,有Animate CSS的大多数类且还扩展了一些。
<div class="vivify slideInLeft"></div>
使用 js 方式:
document.querySelector('.my-element').classList.add('vivify', 'slideInLeft')
使用 JQ 方式:
$(".my-element").addClass("vivify slideInLeft")
与Animate CSS一样,Vivify 还提供了一些类来控制动画的持续时间和延迟。
延迟和持续时间类在以下间隔中可用:
<div class="delay|duration-{100|150|200|250...1000|1250|1500|1750...10750}"></div>
网站地址: www.minimamente.com/project/mag… 网站描述: Magic CSS3 Animations 是 CSS3 动画的包,伴有特殊的效果,用户可以自由的在 web 项目中使用。
<div class="magictime fadeIn"></div>
使用 JS 方式:
document.querySelector('.my-element').classList.add('magictime', 'fadeIn')
使用 JQ 方式:
$(".my-element").addClass("magictime fadeIn")
cssanimation.io是一大堆不同动画的集合,总共大概有200个,这很强大。如果你连在这里都没有找到你所需的动画,那么在其它也将很难找到。
它的工作原理与 Animista 类似。例如,可以选择一个动画并直接从站点获取代码,或者也可以下载整个库。
用法: 将cssanimation {animation_name}添加到指定的元素上。
<div class="cssanimation fadeIn"></div>
使用 JS
document.querySelector('.my-element').classList.add('cssanimation','fadeIn')
使用 JQ
$(".my-element").addClass("cssanimation fadeIn")
还可以添加 infinite 类,这样动画就可以循环播放。
<div class="cssanimation fadeIn infinite"></div>
此外,cssanimation.io还为我们提供了动漫字母的功能。使用这个需要引入letteranimation.js文件,然后将le {animation_name}添加到我们的文本元素中。
<div class="cssanimation leSnake"></div>
要使字母按顺序产生动画,添加sequence类,要使它们随机产生动画,添加random类。
<div class="cssanimation leSnake {sequence|random}"></div>
如果使用不同的生成器,Angrytools实际上是一个集合,其中还包括CSS动画生成器。
它可能不像Animista那么复杂,但我觉得这个也很不错。这个站点还提供了一些自定义动画的特性,比如动画的持续时间或延迟。
但是我喜欢的是,我们可以在其展示时间轴上添加自定义的keyframes,然后可以直接在其中编写代码。 另外,也可以编辑现有的。
当我们完成的时候,可以得到完整的动画代码,也可以下载它。
网站地址: ianlunn.github.io/Hover/ 网站描述: 纯CSS3鼠标滑过效果动画库
Hover.css是许多CSS动画的集合,与上面的动画不同,每次将元素悬停时都会触发。
一组CSS3支持的悬停效果,可应用于链接、按钮、徽标、SVG和特色图像等。 ** 用法
它非常简单:只需将类的名称添加到元素中,比如
<button class="hvr-fade">Hover me!</button>
WickedCSS是一个小的CSS动画库,它没有太多的动画变体,但至少有很大的变化。 其中大多数是我们已经熟悉的基础知识,但它们确实很干净。
它的用法很简单,只需将动画的名称添加到元素中即可。
<div class="bounceIn"></div>
使用 JS
document.querySelector('.my-element').classList.add('bounceIn')
使用 JQ
$(".my-element").addClass("bounceIn")
网站地址: nzbin.github.io/three
Three Dots是一组CSS加载动画,它由三个点组成,而这些点仅由单个元素组成。
用法: 只需创建一个div元素,并添加动画的名称
<div class="dot-elastic"></div>
网站地址: elrumordelaluz.github
顾名思义,CSShake是一个CSS动画库,其中包含不同类型的震动动画。
用法: 将shake {animation name}添加到元素中。
<div class="shake shake-hard"></div>
使用 JS
document.querySelector('.my-element').classList.add('shake','shake-hard')
使用 JQ
$(".my-element").addClass("shake shake-hard")
设计CSS动画的方法通常涉及以下几个步骤:
明确动画目标和效果:首先,确定您想要实现的动画效果,包括元素的移动、变形、渐变等。考虑动画的目的是增强用户体验、提高页面吸引力还是传达特定信息。
选择合适的动画类型:根据您的动画目标,选择适合的动画类型。常见的CSS动画类型包括关键帧动画(@keyframes)、过渡(transition)、变换(transform)等。
确定动画的触发条件:考虑何时触发动画,例如当用户与页面交互时、页面加载时、或者在特定条件下触发动画。这可以通过JavaScript事件、CSS伪类、或者动态类名等方式实现。
编写CSS代码:根据选择的动画类型和触发条件,编写相应的CSS代码。使用关键帧动画来定义动画的具体效果,或者使用过渡和变换来实现简单的动画效果。
调试和优化:测试动画在不同浏览器和设备上的表现,并根据需要进行调整和优化。确保动画流畅、自然,并且不会影响页面性能和用户体验。
添加交互和反馈:考虑为动画添加交互性和反馈效果,例如当用户悬停在元素上时改变动画速度或颜色,或者在动画完成时显示提示信息。
持续改进:根据用户反馈和页面需求持续改进动画效果,确保它们与页面的整体设计和功能相协调。
通过以上步骤,您可以设计出吸引人的、有效的CSS动画,提升页面的交互性和吸引力。
例子:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>CSS Animation Example</title>
<style>
.box {
width: 100px;
height: 100px;
background-color: #3498db;
transition: transform 0.3s ease-in-out, background-color 0.3s ease-in-out;
}
.box:hover {
transform: rotate(45deg) scale(1.5);
background-color: #e74c3c;
}
@keyframes rotateAnimation {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
.rotate {
animation: rotateAnimation 3s linear infinite;
}
</style>
</head>
<body>
<div class="box rotate"></div>
</body>
</html>
在这个案例中:
.box 类元素是一个正方形的蓝色方块。.box 类元素的样式会通过过渡效果逐渐改变:它会旋转45度并放大1.5倍,并且背景颜色会从蓝色变为红色,这两个改变会在0.3秒内完成。rotate的关键帧动画,使其在3秒内以线性方式无限次地从0度旋转到360度,从而实现了旋转的效果。这个案例展示了如何结合使用关键帧动画、过渡和变换,创建一个简单而引人注目的CSS动画。