CSS3过渡与动画

栏目: CSS · 发布时间: 5年前

内容简介:CSS3中出现很多新的特性,下面就讲一下其中比较好玩的过渡就是使瞬间的样式变化,按照一定方式变得缓慢平缓;例如鼠标划过超链接时颜色的变化,点击按钮后的颜色变化等,默认转化都是瞬间完成,可能你已经习惯了这种变换,但有时候平缓一些看着还是比较舒适的;

CSS3中出现很多新的特性,下面就讲一下其中比较好玩的 3D操作过渡动画 效果;

过渡(transition)

过渡就是使瞬间的样式变化,按照一定方式变得缓慢平缓;

例如鼠标划过超链接时颜色的变化,点击按钮后的颜色变化等,默认转化都是瞬间完成,可能你已经习惯了这种变换,但有时候平缓一些看着还是比较舒适的;

要实现样式的过渡变化,那么首先就学要有 样式变换 ,例如鼠标划过,单击按钮,点击图片等操作,来实现颜色,尺寸,位置等样式的变化;

下面是鼠标划过段落使文本变红的操作,应用所有 transition 属性:

p:hover {
    color: red;
}
p {
    transition-property: color;
    transition-duration: 2s;
    transition-timing-function: linear;
    transition-delay: 0;
}

CSS3过渡与动画

一共四个值,功能基本都是字面翻译的意思:

  • transition-property

执行过渡的属性,例子设置为颜色color的变化,也可以是width, font-size等,不设置的话默认是 all ,即所有属性;

  • transition-duration

过渡的时间,单位是秒,如1s, 2.3s,不设置的话默认 0s ,即无过渡效果;

  • transition-timing-function

设置过渡时的变化方式,默认是 ease ,即速度由慢到快再到慢,常用的还有 linear ,线性变化速度均匀,还有其他几个方式,过渡时间短的话看不出什么区别;

  • transition-delay

延迟时间,即多少秒后执行过渡效果,默认 0s ,不延迟;

当然这么多单词可能记不住,一般使用快捷写法:

p {
    transition: color 2s linear 0;
}
/*最少要指定过渡时间*/
p {
    transition: 2s;
}

也可以设置每个样式分别过渡,例如:

p {
    transition: color 2s linear,
                font-size .5s,
                background: 1s;
}

每个样式过渡之间用 逗号 隔开就行了;

最后,由于是新特性,为了兼容性需要加上浏览器厂商前缀:

p {
    transition: 2s;
    -webkit-transition: 2s;
    -moz-transition: 2s;
    -ms-transition: 2s;
    -o-transition: 2s;
}

动画(animation)

CSS3的动画是个很不错的技术,基本能取代一些动图,javascript,flash等;

而动画里最重要的概念就是 关键帧 ,也许你用PS做gif动图的时候看见过这个概念,所谓动画就是一帧一帧图片连续切换实现的效果,关键帧就是里面主要的一些帧;

实现CSS动画也需要设置关键帧 @keyframes

@keyframes my-animation {
    0% {
        color: red;
    }
    50% {
        color: green;
    }
    100% {
        color: blue;
    }
}

格式如上,@keyframes后面跟的是自定义的 动画名称 ,后面会用到。里面的 0%,50%,100% 便是设置的三个关键帧及其对应样式,如果只需要设置首尾两个关键帧,可以这样写:

@keyframes my-animation {
    from {
        color: green;
    }
    to {
        color: blue;
    }
}

效果:

CSS3过渡与动画

当然样式除了color还能设置多项样式;

定义好关键帧后就直接在需要应用动画的元素标签内使用就行了,格式及所有属性如下:

p {
    animation-name: my-animation;
    animation-duration: 3s;
    animation-timing-function: ease;
    animation-delay: 0;
    animation-iteration-count: 3;
    animation-direction: normal;
    animation-play-state: running;
}

发现了吧,很多属性和 transition 里面一样,简单介绍下:

  • animation-name

就是之前跟在@keyframea后面的自定义名称,之前设置的是 my-animation ;

  • animation-duration
  • animation-timing-function
  • animation-delay

和前面一样,默认分别为 0, ease, 0

  • animation-iteration-count

动画播放的次数,默认 1 ,但一般设置为 infinite ,即无限循环;

  • animation-direction

动画播放的方向, normal 为默认,正向播放, reverse 为反向播放, alternate 为正向后反向, alternate-reverse 为反向后正向;

  • animation-play-state

播放状态,默认 running ,运行, paused 为暂停,可以在javascript中使用对动画进行控制;

当然,这个属性比之前的transition还多,也有简便写法:

p {
    animation: my-animation 3s linear infinite alternate;
}

其中 animation-nameanimation-duration 为必须设置的属性;

同样,记得考虑浏览器兼容:

@-webkit-keyframes mycanimation {
    from {
        color: green;
    }
    to {
        color: blue;
    }
}
p {
    -webkit-animation: my-animation 3s linear infinite;
}
/* -moz-, -ms-, -o- 格式类似 */

以上所述就是小编给大家介绍的《CSS3过渡与动画》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构与算法分析

数据结构与算法分析

[美]Mark Allen Weiss / 张怀勇 / 人民邮电出版社 / 2007年 / 49.00元

《数据结构与算法分析:C++描述(第3版)》是数据结构和算法分析的经典教材,书中使用主流的程序设计语言C++作为具体的实现语言。书的内容包括表、栈、队列、树、散列表、优先队列、排序、不相交集算法、图论算法、算法分析、算法设计、摊还分析、查找树算法、k-d树和配对堆等。《数据结构与算法分析:C++描述(第3版)》适合作为计算机相关专业本科生的数据结构课程和研究生算法分析课程的教材。本科生的数据结构课......一起来看看 《数据结构与算法分析》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具