`

CSS3动画库animate.css详解

阅读更多

演示网站animate.css

 

【概括】

   虽说IE9以及更早版本的IE浏览器都不支持css3动画,但是IE6-8浏览器已是旧时代了。使用谷歌浏览器、火狐浏览器、IE10+浏览器以及移动端浏览器等这些支持css3动画的浏览器的人数越来越多,所以如果很简单的就能让一部分人获得更好的用户体验,那何乐而不为呢

   接下来,我们先了解下css3动画,然后讲解animate.css的用法

 

【css3动画简介】

从广义上来讲,css3动画可以分为两种:过渡动画和关键帧动画

这里我简单概括下,具体详解我在之前文章里做过介绍

 

【分类】

下面分别介绍下过渡动画transition和关键帧动画keyframes

(1)过渡动画transition

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

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

transition-property:规定对哪个属性进行过渡
transition-duration:定义过渡的时间,默认是0
transition-timing-function:定义过渡动画的缓动效果,如淡入、淡出等,默认是 ease
transition-delay:规定过渡效果的延迟时间,即在过了这个时间后才开始动画,默认是0

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

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

div{transition:width 3s;}相当于div{transition:width 3s ease 0;}

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

div{transition:width 3s, height 3s, background-color 3s;}

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

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

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

 

(2)关键帧动画keyframes

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

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

@keyframes 动画名称{
      时间点 {元素状态}
      时间点 {元素状态}
      …
}

   例如:

   QQ截图20131102123530

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

   关键帧的书写方式很灵活,一行可以写多个关键帧,甚至它们之间的空格也是可以不要的

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

   QQ截图20131102123530

 

【animate.css简介】

   animate.css 是一个来自国外的 CSS3 动画库,它预设了抖动(shake)、闪烁(flash)、弹(bounce)、翻转(flip)、旋转(rotateIn/rotateOut)、淡入淡出(fadeIn/fadeOut)等多达 60 多种动画效果,几乎包含了所有常见的动画效果。

   虽然借助 animate.css 能够很方便、快速的制作 CSS3 动画效果,但还是建议看看 animate.css 的代码,也许你能从中学到一些东西。

 

【兼容】

浏览器兼容:当然是只兼容支持 CSS3 animate 属性的浏览器,他们分别是:IE10+、Firefox、Chrome、Opera、Safari。

 

【animate.css用法】

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

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

<link rel="stylesheet" type="text/css" href="animate.css">
   然后你想要哪个元素进行动画,就给那个元素添加上animated类 以及特定的动画类名,animated是每个要进行动画的元素都必须要添加的类。

 

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

$(document).ready(function(){
        $(".gradient").addClass('animated pulse');
})
   这样载入页面,元素就能动起来了。你也可以在动画完成后,把动画类移除,以便可以再次进行同一个动画。
$(document).ready(function(){
        $(".gradient").addClass('animated pulse');
        setTimeout(function(){
            $(".gradient").removeClass('pulse');
        },1000)
})
   有些动画效果最后会让元素不可见,比如淡出、向左滑动等等,可能你又需要将 class 删除,比如:
$(function(){
    $('#dowebok').addClass('animated bounce');
    setTimeout(function(){
        $('#dowebok').removeClass('bounce');
    }, 1000);
});
   至于动画的配置参数,比如动画持续时间,动画的执行次数等等,你可以在你的的元素上自行定义,覆盖掉animate.css里面所定义的就行了。

   比如这里我要循环无数次:

animation-iteration-count:infinite ;
-webkit-animation-iteration-count:infinite ;
-o-animation-iteration-count:infinite ;
-moz-animation-iteration-count:infinite ;
   注意这些属性还要记得加上各浏览器的前缀。
   总之是很灵活的,说到底就是一个css文件,一看就懂的,你在里面想怎么整就怎么整,不想用它提供的类名,就在里面改掉就行了。如果你只想用里面的部分动画,也可以把那些要使用的动画分离出来,它的官网也提供了这样的功能。
      

 

 

 

 

.

分享到:
评论

相关推荐

    动画库文件 animate.min.zip

    总结起来,"animate.min.zip"中的"animate.min.css"文件是一个强大且易用的CSS动画库,它为开发者提供了丰富的预设动画效果,简化了动态效果的实现过程,同时考虑到了浏览器兼容性和性能优化。无论你是初学者还是...

    jQuery+animate.css自定义弹窗动画插件.zip

    而animate.css则是一个预定义的动画库,包含了多种现成的CSS3动画。将jQuery与animate.css结合,我们可以轻松地创建出自定义的弹窗动画,让网站更加生动有趣。本文将深入探讨如何使用jQuery和animate.css构建一个...

    18种炫酷CSS3动画效果库Mimic.css

    **CSS3库Mimic.css详解** Mimic.css是一个专为前端开发者设计的CSS3动画效果库,它集合了18种独特的、引人注目的动画效果,旨在提升网页的交互性和视觉吸引力。与知名的animate.css类似,Mimic.css以简洁易用的方式...

    jquery支持animate.css动画的弹出层插件jquery.popup.js.zip

    Animate.css库提供了一系列预定义的CSS3动画,如淡入淡出、滑动、旋转等,只需简单地添加类名即可应用。在jQuery.popup.js中,开发者可以方便地将这些动画效果应用到弹出层的打开和关闭过程中,增强了用户体验。 该...

    animate.min.zip

    首先,"animate.min.css"是一个流行的CSS动画库,它包含了一系列预定义的动画效果,这些效果可以方便地应用到HTML元素上,无需编写复杂的CSS关键帧动画。这个库的核心在于其简洁的类名系统,允许开发者通过添加特定...

    vue过渡和animate.css结合使用详解

    Animate.css 是一个 CSS 动画库,提供了多种预定义的动画效果,可以轻松地将动画应用于 Web 应用程序中。 Vue 过渡和 Animate.css 结合使用 在 Vue 中,我们可以使用 Animate.css 来实现过渡动画。AniMate.css ...

    css3动画详解

    尽管大多数现代浏览器都支持CSS3动画,但在开发时应考虑老版本浏览器的兼容性,可以借助前缀(如 `-webkit-`)和JavaScript库(如jQuery的`.animate()`方法)来确保更广泛的兼容性。 通过理解和熟练运用CSS3动画,...

    css3样式动画

    在给定的文件列表中提到了`animate.css`,这是一个非常流行的预定义CSS3动画库。它包含了一系列现成的动画效果,如`bounce`、`flip`、`fadeIn`等,只需简单地添加类名到元素上即可实现相应的动画效果。例如,要使一...

    swiper+animate.docx

    而Animate则是一套动画库,通常指的是Animate.css,它提供了一系列预定义的CSS动画,便于开发者快速地给元素添加各种动画效果。将Swiper与Animate结合起来,可以轻松地实现整屏网站的滚动效果,并为页面元素添加丰富...

    WebKit CSS3 动画基础

    因此,确保进行跨浏览器测试,并为不支持 CSS3 动画的浏览器提供备选方案,比如使用 JavaScript 动画库。 综上所述,WebKit CSS3 动画是构建动态网页的重要技术,通过理解和熟练掌握这些概念和技巧,开发者能够创造...

    jQuery CSS3酷炫文字动画插件.zip

    《jQuery与CSS3结合打造的文字动画插件详解》 在当今网页设计中,动态效果的运用已经成为提升用户体验的重要手段之一。jQuery作为一个强大的JavaScript库,它简化了DOM操作,事件处理,动画效果等任务,而CSS3则为...

    jQuery CSS3动画过渡效果特效.zip

    《jQuery与CSS3结合的动画过渡效果详解》 在网页设计和开发中,动态效果的运用可以提升用户体验,增加互动性。"jQuery CSS3动画过渡效果特效.zip" 提供了两种不同的jQuery特效,它们巧妙地结合了jQuery的强大功能和...

    css3动画效果

    通过简单的配置,Wow.js可以与Animate.css等CSS动画库配合,轻松添加“哇”效果,当用户滚动页面时,元素会突然出现或者以特定方式进入视线。 5. **CSS3动画在网站中的应用** CSS3动画广泛应用于网页加载指示器、...

    jQuery+CSS3线性时钟插件.zip

    - **jQuery动画**:使用`.animate()`方法,结合CSS3动画,可以创建更复杂的动画效果。 ### 文件结构分析 - `index.html`: 主要HTML文件,包含插件运行所需的DOM结构。 - `style.css`: CSS文件,定义了时钟的样式和...

    jquery-aniview:一个与animate.css协调工作的jQuery插件,以便仅在内容出现时才启用动画

    动画库animate.css animate.css是一个包含大量预定义CSS动画的库,使得开发者无需编写复杂的CSS代码即可实现各种酷炫的动画效果。它包含了淡入淡出、滑动、旋转等众多类别,覆盖了网页设计中的大部分需求。 ### 2...

    WOWjs元素在页面滚动时展示CSS3动画JS插件

    2. **自定义动画库**:虽然默认情况下,WOW.js与animate.css配合使用,但开发者可以根据需求选择其他CSS3动画库,如Hinge、BounceIn、FadeIn等,以实现各种独特的效果。 3. **设置延迟和持续时间**:开发者可以通过...

    美食天下CSS3网页模板是一款橙色好看的CSS3美食网站模板下载.rar

    2. **Animate.css**:`animate.css`是一个预定义的动画库,它包含了一系列CSS3动画效果,如淡入淡出、滑动、旋转等,用于增强网页元素的动态效果,为"美食天下"模板增添视觉吸引力。 3. **Style.css**:`style.css`...

    jQuery CSS3云朵飘动动画特效.zip

    《jQuery与CSS3结合实现云朵飘动动画特效详解》 在网页设计中,动态效果往往能提升用户体验,增加网站的吸引力。"jQuery CSS3云朵飘动动画特效"就是一个典型的例子,它巧妙地结合了jQuery的强大功能和CSS3的动画...

Global site tag (gtag.js) - Google Analytics