作者:Patrik Kiss 译者:前端小智 来源:dev
1.Animista
网站地址:http://animista.net/网站描述:在线生成 css 动画
![272d762f4fc710135b26b4bf04098633.png](https://i-blog.csdnimg.cn/blog_migrate/50ebeee68470924ed207dc64fe6d2f02.jpeg)
Animista是一个在线动画生成器,同时也是一个动画库,它为我们提供了以下功能
1. 选择不同的动画
我们可以选择想要的动画类型(例如entrance/exist),除了可以选择某个动画(例如,scale-in)外,甚至还可以为该动画选择不同的展示效果(例如:scale-in-right)。
![1d9fd304f13b19f6781707abcbdff8d9.png](https://i-blog.csdnimg.cn/blog_migrate/2d876eeb6a6f9d4f56e38819d5cc12d3.jpeg)
2. 定制
Animista还提供了一个功能,允许我们定制动画的某些部分,比如
- duration
- delay
- direction
更好的是,可以选择要设置动画的对象:
![2d402ed42044965ebda7c383823189dd.png](https://i-blog.csdnimg.cn/blog_migrate/4fcf01890ea8b2d808f78c11d7fb4f86.jpeg)
3. 生成CSS代码
选择适合自己需要的动画后,我们可以直接从网站上获取代码,甚者可以进行压缩:
![381a761f472caa2f404c68d336441a40.png](https://i-blog.csdnimg.cn/blog_migrate/67b0dc75b7a425b60aafeb6b06e14d29.jpeg)
4. 下载代码
另一个好用的功能是,可以把自己收藏自己喜欢的动画,然后一起下载下来, 或者,我们也可以选择将这些动画的代码复制到一起。
![2293a7883629d714dfe19c14d18e1c6d.png](https://i-blog.csdnimg.cn/blog_migrate/ce39a3c39a6e7564d4f85be2ced80c0b.jpeg)
2. Animate CSS
网站地址:http://daneden.github.io/animate.css
网站描述:齐全的CSS3动画库
![823286be8dd233a4d3d8c0cf8d5de136.png](https://i-blog.csdnimg.cn/blog_migrate/e0a8f8dc0cbc99417b7354d66f4234ec.jpeg)
想必这个不用介绍,大部分人都知道了。Animate CSS 可能是最著名的动画库之一。这里简要介绍一下它的用法:
1. 用法
首先,必须在总需要动画元素上添加类animated ,然后是动画的名字。
如果我们想让动画一直持续,可以添加infinite类。
通过 JS 来添加动画:
document.querySelector('.my-element').classList.add('animated', 'slideInLeft')
通过 JQ 来添加动画:
$(".my-element").addClass("animated slideInLeft")
2. 其它功能
Animate CSS提供了一些基本的类来控制动画的延迟和速度。
** delay **
可以添加 delay 类来延迟动画的播放。
** speed **
我们还可以通过添加如下列出的类之一来控制动画速度。
类名速度时间show2sslower3sfast800msfaster500ms
3. Vivify
3. Vivify
网站地址: http://vivify.mkcreative.cz/
网站描述: 一个更加丰富css动画库
![1316091ad941c3b1ac5ce8ac50c6b69b.png](https://i-blog.csdnimg.cn/blog_migrate/64173f97be690b4a86931d285c4f5e54.jpeg)
Vivify 是一个动画库,可以看作是Animate CSS的增强版。它们的工作方式完全相同,有Animate CSS的大多数类且还扩展了一些。
使用 JS 方式:
document.querySelector('.my-element').classList.add('vivify', 'slideInLeft')
使用 JQ 方式:
$(".my-element").addClass("vivify slideInLeft")
与Animate CSS一样,Vivify 还提供了一些类来控制动画的持续时间和延迟。
延迟和持续时间类在以下间隔中可用:
4. Magic Animations CSS3
4. Magic Animations CSS3
网站地址: https://www.minimamente.com/project/magic/
网站描述: Magic CSS3 Animations 是 CSS3 动画的包,伴有特殊的效果,用户可以自由的在 web 项目中使用。
![620d099027df2f11b36f4f9a79730804.png](https://i-blog.csdnimg.cn/blog_migrate/a6ff87a1f4bad53142889b1c5eb7a090.jpeg)
这个动画库有一些非常漂亮和流畅的动画,特别是3D的。没什么好说的,自己去尝试。
使用 JS 方式:
document.querySelector('.my-element').classList.add('magictime', 'fadeIn')
使用 JQ 方式:
$(".my-element").addClass("magictime fadeIn")
5. cssanimation.io
5. cssanimation.io
![7af6411576117fd253fb98e9e2168846.png](https://i-blog.csdnimg.cn/blog_migrate/fd16648959f9e968071b91b36929f0dc.jpeg)
网站地址: http://cssanimation.io/index.html
cssanimation.io是一大堆不同动画的集合,总共大概有200个,这很强大。如果你连在这里都没有找到你所需的动画,那么在其它也将很难找到。
它的工作原理与 Animista 类似。例如,可以选择一个动画并直接从站点获取代码,或者也可以下载整个库。
![05d2aa4a195d2db7414b6729c5d99770.png](https://i-blog.csdnimg.cn/blog_migrate/433b37cdaf656ebbf36c38bd53b07207.jpeg)
用法
将cssanimation {animation_name}添加到指定的元素上。
使用 JS
document.querySelector('.my-element').classList.add('cssanimation','fadeIn')
使用 JQ
$(".my-element").addClass("cssanimation fadeIn")
还可以添加 infinite 类,这样动画就可以循环播放。
此外,cssanimation.io还为我们提供了动漫字母的功能。使用这个需要引入letteranimation.js文件,然后将le {animation_name}添加到我们的文本元素中。
要使字母按顺序产生动画,添加sequence类,要使它们随机产生动画,添加random类。
Sequence
![683d5242fca9a1daf85b387bfead2d23.gif](https://i-blog.csdnimg.cn/blog_migrate/bcb9c14e1d05d4afcc9ade0b12b4006b.gif)
Random
![43b52f56f83f4e6bee00b0da1af530b6.gif](https://i-blog.csdnimg.cn/blog_migrate/84dd2d00a721d2ec919ede348cec62e4.gif)
6.Angrytools
6.Angrytools
网站地址: https://angrytools.com/css/animation/
如果使用不同的生成器,Angrytools实际上是一个集合,其中还包括CSS动画生成器。
它可能不像Animista那么复杂,但我觉得这个也很不错。这个站点还提供了一些自定义动画的特性,比如动画的持续时间或延迟。
但是我喜欢的是,我们可以在其展示时间轴上添加自定义的keyframes,然后可以直接在其中编写代码。另外,也可以编辑现有的。
![df584cd16e260fac7a3f0f19f430b325.png](https://i-blog.csdnimg.cn/blog_migrate/f5e6e1066f96857d242fd7ae1544b1f2.jpeg)
当我们完成的时候,可以得到完整的动画代码,也可以下载它。
7.Hover.css
7.Hover.css
网站地址: http://ianlunn.github.io/Hover/网站描述: 纯CSS3鼠标滑过效果动画库
Hover.css是许多CSS动画的集合,与上面的动画不同,每次将元素悬停时都会触发。
一组CSS3支持的悬停效果,可应用于链接、按钮、徽标、SVG和特色图像等。
** 用法
它非常简单:只需将类的名称添加到元素中,比如
Hover me!
8.WickedCSS
8.WickedCSS
网站地址: http://kristofferandreasen.github.io/wickedCSS/#
WickedCSS是一个小的CSS动画库,它没有太多的动画变体,但至少有很大的变化。其中大多数是我们已经熟悉的基础知识,但它们确实很干净。
它的用法很简单,只需将动画的名称添加到元素中即可。
** 使用 JS
document.querySelector('.my-element').classList.add('bounceIn')
** 使用 JQ
$(".my-element").addClass("bounceIn")
![74bfdb1aa570db9d29a55f13056dda27.png](https://i-blog.csdnimg.cn/blog_migrate/848d4899703289bb5d2939be35472401.jpeg)
9.Three Dots
9.Three Dots
网站地址: http://kristofferandreasen.github.io/wickedCSS/#
Three Dots是一组CSS加载动画,它由三个点组成,而这些点仅由单个元素组成。
** 用法
只需创建一个div元素,并添加动画的名称
10.CSShake
10.CSShake
网站地址: http://kristofferandreasen.github.io/wickedCSS/#
![52c26b6bef7b64572b3181b36bbc33be.png](https://i-blog.csdnimg.cn/blog_migrate/4e244062fa87da81ce85e4254ed2cfc2.jpeg)
顾名思义,CSShake是一个CSS动画库,其中包含不同类型的震动动画。
** 用法
将shake {animation name}添加到元素中。
** 使用 JS **
document.querySelector('.my-element').classList.add('shake','shake-hard')
** 使用 JQ **
$(".my-element").addClass("shake shake-hard")
原文:https://dev.to/weeb/10-of-the-best-css-animation-libraries-31d7