`
shuai1234
  • 浏览: 978529 次
  • 性别: Icon_minigender_1
  • 来自: 山西
社区版块
存档分类
最新评论

css3动画简介以及动画库animate.css的使用

 
阅读更多

 

       在这个年代,你要是不懂一点点css3的知识,你都不好意思说你是个美工。美你妹啊,请叫我前端工程师好不好。呃。。好吧,攻城尸。。。呵呵,作为一个攻城尸,没有点高端大气上档次的东西怎么能行呢,那么css3的动画就绝对是值得你拥有了,虽说IE9以及更早版本的IE浏览器都不支持css3动画,但是IE6-8浏览器已是江河日下,使用谷歌浏览器、火狐浏览器、IE10+浏览器以及移动端浏览器等这些支持css3动画的浏览器的人数越来越多,所以如果很简单的就能让一部分人获得更好的用户体验,那何乐而不为呢。

从广义上来讲,css3动画可以分为两种。

 

过渡动画

       第一种叫过渡(transition)动画,就是从初始状态过渡到结束状态这个过程中所产生的动画。所谓的状态就是指大小、位置、颜色、变形(transform)等等这些属性。css过渡只能定义首和尾两个状态,所以是最简单的一种动画。

要想使一个元素产生过渡动画,首先要在这个元素上用transition属性定义动画的各种参数。可定义的参数有

transition-property:规定对哪个属性进行过渡

transition-duration:定义过渡的时间,默认是0

transition-timing-function:定义过渡动画的缓动效果,如淡入、淡出等,默认是 ease

transition-delay:规定过渡效果的延迟时间,即在过了这个时间后才开始动画,默认是0

QQ截图20131102123530 

 

为了书写方便,也可以把这四个属性按照以上顺序简写在一个 transition 属性上:

QQ截图20131102123530

 

如果是使属性的默认值,则可以省略:

QQ截图20131102123530 相当于:QQ截图20131102123530

 

如果想要同时过渡多个属性,可以用逗号隔开,如:

QQ截图20131102123530

 

使用transtion属性只是规定了要如何去过渡,要想让动画发生,还得要有元素状态的改变。如何改变元素状态呢,当然就是在css中给这个元素定义一个类(:hover等伪类也可以),这个类描述的是过渡动画结束时元素的状态。

QQ截图20131102123530

这样,当我们把鼠标移动到div上的时候,div的状态发生了变化,就能看到宽度从100到400,高度从100到400,背景颜色从黑到红的,过渡时间为3秒的过渡效果了。

除了使用hover等系统提供的伪类外,我们也可以随意的定义自己的类,然后想要过渡时就通过js把类加到元素上面:

QQ截图20131102123530

 

 

 

关键帧动画

       第二种叫做关键帧(keyframes)动画。不同于第一种的过渡动画只能定义首尾两个状态,关键帧动画可以定义多个状态,或者用关键帧来说的话,过渡动画只能定义第一帧和最后一帧这两个关键帧,而关键帧动画则可以定义任意多的关键帧,因而能实现更复杂的动画效果。

关键帧动画的定义方式也比较特殊,它使用了一个关键字 @keyframes 来定义动画。具体格式为:

@keyframes 动画名称{

      时间点 {元素状态}

      时间点 {元素状态}

      …

}

例如:

QQ截图20131102123530

        这段代码定义了一个名为demo,且有5个关键帧的动画。0% ,10% 等这些表示的是时间点,是相对于整个动画的持续时间来说的,时间点之后的花括号里则是元素的状态属性集合,描述了这个元素在这个时间点的状态,动画发生时,就是从第一个状态到第二个状态进行过渡,然后从第二个状态到第三个状态进行过渡,直到最后一个状态。一般来说,0%和100%这两个关键帧是必须要定义的。

 

关键帧的书写方式很灵活,一行可以写多个关键帧。

QQ截图20131102123530

甚至它们之间的空格也是可以不要的。

 

现在我们知道了怎么去定义一个关键帧动画了,那怎么去实现这个动画呢?其实很简单,只要把这个动画绑定到某个要进行动画的元素上就行了。

把动画绑定到元素上,我们可以使用animation属性。animation属性有以下这些:

QQ截图20131102123530

像前面讲的transition属性一样,也可以把这些animation属性简写到一个animation中,使用默认值的也可以省略掉。但 animation-play-state 属性不能简写到animation中。

QQ截图20131102123530

 

只要像这样把定义好的动画绑定到元素上,就能实现关键帧动画了,而不是像第一种过渡动画那样,需要一个状态的改变才能触发动画。

QQ截图20131102123530

--------------------------------------------------------------------------------------------------------------------

注意,为了达到最佳的浏览器兼容效果,在实际书写代码的时候,还必须加上各大浏览器的私有前缀

QQ截图20131102123530

 

 

animate.css的使用

animate.css是一个css3动画库,可以到github上去下载,里面预设了很多种常用的动画,可以先在本页看下演示效果,使用也很简单,因为它是把不同的动画绑定到了不同的类里,所以我们想要使用哪种动画的时候,只需要简单的把那个相应的类添加到元素上就行了:

 

首先在head中引入下载的animate.css文件

QQ截图20131102123530

 

然后你想要哪个元素进行动画,就给那个元素添加上animated类 以及特定的动画类名,animated是每个要进行动画的元素都必须要添加的类。

假设使用jquery,要给一个id为demo的元素添加一个摇动的动画,因为摇动的动画类名为shake,所以代码是这样的:

QQ截图20131102123530

 

这样载入页面,元素就能动起来了。你也可以在动画完成后,把动画类移除,以便可以再次进行同一个动画。

QQ截图20131102123530

 

至于动画的配置参数,比如动画持续时间,动画的执行次数等等,你可以在你的的元素上自行定义,覆盖掉animate.css里面所定义的就行了。

QQ截图20131102123530

注意这些属性还要记得加上各浏览器的前缀。

总之是很灵活的,说到底不就是一个css文件吗,一看就懂的,你在里面想怎么整就怎么整,不想用它提供的类名,就在里面改掉就行了。如果你只想用里面的部分动画,也可以把那些要使用的动画分离出来,它的官网也提供了这样的功能

 

 

 

 

 

下面展示了animate.css里面提供的所有动画,动画名就是类名,你想使用哪个动画,加上这个类名就行了。

 

 

shakeflashswingbouncetadawobblepulse

flipflipInXflipOutXflipInYflipOutY

fadeInfadeInUpfadeInDownfadeInLeftfadeInRightfadeInUpBigfadeInDownBigfadeInLeftBigfadeInRightBig

fadeOutfadeOutUpfadeOutDownfadeOutLeftfadeOutRightfadeOutUpBigfadeOutDownBigfadeOutLeftBigfadeOutRightBig

slideInDownslideInLeftslideInRightslideOutUpslideOutLeftslideOutRight

bounceInbounceInDownbounceInUpbounceInLeftbounceInRight

bounceOutbounceOutDownbounceOutUpbounceOutLeftbounceOutRight

rotateInrotateInDownLeftrotateInDownRightrotateInUpLeftrotateInUpRight

rotateOutrotateOutDownLeftrotateOutDownRightrotateOutUpLeftrotateOutUpRight

lightSpeedInlightSpeedOuthingerollInrollOut

分享到:
评论

相关推荐

    animate(CSS动画库)

    Animate.css 是一个强大的开源CSS动画库,它提供了一系列预先定义好的动画效果,使得开发者无需从零开始编写复杂的CSS代码,就能轻松实现各种炫酷的动态效果。这个库被广泛应用于网页设计,提升用户体验,吸引用户...

    Animate.css 一款强大的预设css3动画库

    Animate.css 是一个强大的预设CSS3动画库,它为开发者提供了丰富的动画效果,极大地简化了在Web项目中添加动态效果的工作。这个库包含了各种各样的动画类型,如淡入淡出、滑动、旋转、缩放等,适用于按钮、图标、...

    animate.min.css动画特效

    总之,Animate.min.css是一个强大的CSS动画库,它为开发者提供了大量现成的动画效果,使得在网页设计中实现动态视觉效果变得简单快捷。无论你是前端新手还是经验丰富的开发者,Animate.css都是一个值得信赖的工具,...

    强大的CSS3动画库animate.css 50多种动画形式

    **CSS3 动画库 animate.css 深度解析** CSS3是现代网页设计的关键技术之一,它提供了许多增强用户体验的特性,其中动画效果尤其引人注目。animate.css是一个非常强大的开源CSS3动画库,它集合了大约50种预定义的...

    animate.css 是一个 CSS3 动画库,它预设了抖动、闪烁、弹跳等多种动画效果

    Animate.css 是一个强大的开源 CSS3 动画库,它为开发者提供了一系列预先设计好的动画效果,使得在网页设计中添加动态元素变得简单易行。这个库包含了许多有趣的动画,如抖动、闪烁、弹跳等,可以极大地提升用户体验...

    animate.css动画库,汉化注释

    一个css大神制作的成品的动画库,对控件动画有效,我做了测试和动画效果注释汉化。因为不是自己的东西,就不要分了,当然百度的静态资源库应该也是有的,不过对于初学者,注释还是很有必要的。截止2015年12月1号的...

    animate.css-4.1.1.zip

    Animate.css是一个CSS3动画库,它使得在网页上添加复杂的动画变得简单快捷。通过在HTML元素上直接应用预定义的类名,就可以轻松实现各种动态效果,如淡入淡出、滑动、旋转、放大缩小等。这极大地简化了开发者的工作...

    animate.css动画属性制作css3动画效果

    animate.css 是由 Daniel Eden 开发的一个 CSS3 动画库,它包含了大量的动画效果,如淡入淡出、旋转、滑动等。每个动画都是一个独立的 CSS 类,可以直接应用到 HTML 元素上。通过简单地将相应的类名添加到元素中,就...

    68种动画效果的CSS3动画库vivify.css

    Vivify.css是一款带68种动画效果的CSS3动画库。vivify.css动画库和Animate.css类似,为网页元素提供各种CSS3动画效果。vivify.css动画库内置了68种炫酷的CSS3动画效果。

    wow.min.js和animate.css

    "animate.css"则是一个预定义的CSS3动画库,包含了大量的动画效果,如淡入淡出、滑动、旋转等。开发者可以通过简单地添加类名到HTML元素上,就能轻松实现各种炫酷的动画效果。这些动画效果都是基于现代浏览器支持的...

    基于animate.css动画库的全屏滚动,适用于vue.js(移动端、pc)项目。.zip

    在本项目中,我们关注的是一个使用Animate.css动画库实现的全屏滚动解决方案,特别针对Vue.js框架,可用于移动端和PC端的应用开发。Animate.css是一个强大的、预定义的CSS动画库,可以为网页添加各种炫酷的动画效果...

    Animate.css(css3动画库)

    Animate.css拥有多款文字特效的css3动画库效果源码,是一段拥有数十款文字特效的css3动画库代码,它预设了抖动(shake)、闪烁(flash)、弹跳(bounce)、翻转(flip)、旋转(rotateIn/rotateOut)、淡入淡出...

    animate.min.css

    CSS3动画库

    基于animate.css弹出框弹出关闭特效 (5星级)

    Animate.css 是一个强大的、易于使用的库,它包含了大量的预定义CSS动画效果,可以轻松地为网页元素添加动态效果。这个库极大地简化了开发者的工作,使他们无需深入学习复杂的CSS3动画语法,就能创建出令人眼前一亮...

    动画库animate.css文字特效.zip

    Animate.css是一个广泛使用的开源CSS动画库,为网页设计师和开发者提供了丰富的动画效果。这个压缩包“动画库animate.css文字特效.zip”显然包含了专门针对文字特效的Animate.css样式。以下是对这些知识点的详细解释...

    fullpage.js结合animate.css实现滚屏动画

    fullpage.js结合animate.css实现滚屏动画,每段代码都加有详细注释 文章地址:https://blog.csdn.net/cplvfx/article/details/80649574

    Animate.css拥有多款文字特效的css3动画库效果源码.zip

    Animate.css是一个广受欢迎的开源CSS3动画库,它为网页设计师和开发者提供了丰富的动画效果,无需编写复杂的JavaScript或CSS代码。这个压缩包“Animate.css拥有多款文字特效的css3动画库效果源码.zip”包含了Animate...

    animatecss使用方便跨浏览器的CSS3动画库

    Animate.css 是一个强大的开源库,专门用于为网页元素添加流畅、动态且易于使用的CSS3动画效果。这个库由Dan Eden创建并维护,它的主要优点在于其广泛的浏览器兼容性,覆盖了包括Chrome、Firefox、Safari、Opera以及...

    Animate.css 强大的跨浏览器CSS3动画库

    animate.css是一款功能非常强大的跨浏览器CSS3动画库。animate.css支持多达66种不同的CSS3动画效果,如:翻转、旋转、淡入淡出、滑动、放大缩小等等。最重要的是它几乎兼容所有的浏览器。

Global site tag (gtag.js) - Google Analytics