当前位置:

能解决 80% 需求的 10个 CSS动画库

访客 2024-04-24 914 0

译者:前端小智

来源:dev

点赞再看,微信搜索【大迁世界】关注这个没有大厂背景,但有着一股向上积极心态人。本文GitHubgithub.com/qq449245884…上已经收录,文章的已分类,也整理了很多我的文档,和教程资料。

大家都说简历没项目写,我就帮大家找了一个项目,还附赠【搭建教程】。

目录

1.Animista2.AnimateCSS3.Vivify4.MagicAnimationsCSS35.cssanimation.io6.Angrytools7.Hover.css8.WickedCSS9.ThreeDots10.CSShake

1.Animista

**网站地址:**animista.net/**网站描述:**在线生成css动画

Animista是一个在线动画生成器,同时也是一个动画库,它为我们提供了以下功能

1.选择不同的动画

我们可以选择想要的动画类型(例如entrance/exist),除了可以选择某个动画(例如,scale-in)外,甚至还可以为该动画选择不同的展示效果(例如:scale-in-right)。

2.定制

Animista还提供了一个功能,允许我们定制动画的某些部分,比如

  • duration
  • delay
  • direction

更好的是,可以选择要设置动画的对象:

3.生成CSS代码

选择适合自己需要的动画后,我们可以直接从网站上获取代码,甚者可以进行压缩:

4.下载代码

另一个好用的功能是,可以把自己收藏自己喜欢的动画,然后一起下载下来,或者,我们也可以选择将这些动画的代码复制到一起。

2.AnimateCSS

**网站地址:**daneden.github.io/animate.css

**网站描述:**齐全的CSS3动画库

想必这个不用介绍,大部分人都知道了。AnimateCSS可能是最著名的动画库之一。这里简要介绍一下它的用法:

1.用法

首先,必须在总需要动画元素上添加类animated,然后是动画的名字。

<divclass="animatedslideInLeft"></div>

如果我们想让动画一直持续,可以添加infinite类。

通过JS来添加动画:

document.querySelector('.my-element').classList.add('animated','slideInLeft')

通过JQ来添加动画:

$(".my-element").addClass("animatedslideInLeft")2.其它功能

AnimateCSS提供了一些基本的类来控制动画的延迟和速度。

**delay**

可以添加delay类来延迟动画的播放。

<divclass="animatedslideInLeftdelay-{1-5}"><div>

**speed**

我们还可以通过添加如下列出的类之一来控制动画速度。

速度时间2s3s800ms500ms
类名
show
slower
fast
faster
<divclass="animatedslideInLeftslow|slower|fast|faster"><div>3.Vivify

网站地址:vivify.mkcreative.cz/

网站描述:一个更加丰富css动画库

Vivify是一个动画库,可以看作是AnimateCSS的增强版。它们的工作方式完全相同,有AnimateCSS的大多数类且还扩展了一些。

<divclass="vivifyslideInLeft"></div>

使用JS方式:

document.querySelector('.my-element').classList.add('vivify','slideInLeft')

使用JQ方式:

$(".my-element").addClass("vivifyslideInLeft")

AnimateCSS一样,Vivify还提供了一些类来控制动画的持续时间和延迟。

延迟和持续时间类在以下间隔中可用:

<divclass="delay|duration-{100|150|200|250...1000|1250|1500|1750...10750}"></div>4.MagicAnimationsCSS3

网站地址:www.minimamente.com/project/mag…

网站描述:MagicCSS3Animations是CSS3动画的包,伴有特殊的效果,用户可以自由的在web项目中使用。

这个动画库有一些非常漂亮和流畅的动画,特别是3D的。没什么好说的,自己去尝试。

<divclass="magictimefadeIn"></div>

使用JS方式:

document.querySelector('.my-element').classList.add('magictime','fadeIn')

使用JQ方式:

$(".my-element").addClass("magictimefadeIn")5.cssanimation.io

网站地址:cssanimation.io/index.html

cssanimation.io是一大堆不同动画的集合,总共大概有200个,这很强大。如果你连在这里都没有找到你所需的动画,那么在其它也将很难找到。

它的工作原理与Animista类似。例如,可以选择一个动画并直接从站点获取代码,或者也可以下载整个库。

用法

cssanimation{animation_name}添加到指定的元素上。

<divclass="cssanimationfadeIn"></div>

使用JS

document.querySelector('.my-element').classList.add('cssanimation','fadeIn')

使用JQ

$(".my-element").addClass("cssanimationfadeIn")

还可以添加infinite类,这样动画就可以循环播放。

<divclass="cssanimationfadeIninfinite"></div>

此外,cssanimation.io还为我们提供了动漫字母的功能。使用这个需要引入letteranimation.js文件,然后将le{animation_name}添加到我们的文本元素中。

<divclass="cssanimationleSnake"></div>

要使字母按顺序产生动画,添加sequence类,要使它们随机产生动画,添加random类。

<divclass="cssanimationleSnake{sequence|random}"></div>

Sequence

Random

6.Angrytools

网站地址:angrytools.com/css/animati…

如果使用不同的生成器,Angrytools实际上是一个集合,其中还包括CSS动画生成器。

它可能不像Animista那么复杂,但我觉得这个也很不错。这个站点还提供了一些自定义动画的特性,比如动画的持续时间或延迟。

但是我喜欢的是,我们可以在其展示时间轴上添加自定义的keyframes,然后可以直接在其中编写代码。另外,也可以编辑现有的。

当我们完成的时候,可以得到完整的动画代码,也可以下载它。

7.Hover.css

网站地址:ianlunn.github.io/Hover/网站描述:纯CSS3鼠标滑过效果动画库

Hover.css是许多CSS动画的集合,与上面的动画不同,每次将元素悬停时都会触发。

一组CSS3支持的悬停效果,可应用于链接、按钮、徽标、SVG和特色图像等。

**用法

它非常简单:只需将类的名称添加到元素中,比如

<buttonclass="hvr-fade">Hoverme!</button>8.WickedCSS

网站地址:kristofferandreasen.github.io/wickedCSS/#

WickedCSS是一个小的CSS动画库,它没有太多的动画变体,但至少有很大的变化。其中大多数是我们已经熟悉的基础知识,但它们确实很干净。

它的用法很简单,只需将动画的名称添加到元素中即可。

<divclass="bounceIn"></div>

**使用JS

document.querySelector('.my-element').classList.add('bounceIn')

**使用JQ

$(".my-element").addClass("bounceIn")

9.ThreeDots

网站地址:nzbin.github.io/three-dots/…

ThreeDots是一组CSS加载动画,它由三个点组成,而这些点仅由单个元素组成。

**用法

只需创建一个div元素,并添加动画的名称

<divclass="dot-elastic"></div>10.CSShake

网站地址:elrumordelaluz.github.io/csshake/

顾名思义,CSShake是一个CSS动画库,其中包含不同类型的震动动画。

**用法

shake{animationname}添加到元素中。

<divclass="shakeshake-hard"></div>

**使用JS**

document.querySelector('.my-element').classList.add('shake','shake-hard')

**使用JQ**

$(".my-element").addClass("shakeshake-hard")

代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log调试,这边顺便给大家推荐一个好用的BUG监控工具Fundebug。

原文:dev.to/weeb/10-of-…


交流

文章每周持续更新,可以微信搜索「大迁世界」第一时间阅读和催更(比博客早一到两篇哟),本文GitHubgithub.com/qq449245884…已经收录,整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,另外关注公众号,后台回复福利,即可看到福利,你懂的。

发表评论

  • 评论列表
还没有人评论,快来抢沙发吧~