CSS3中出现很多新的特性,其中比较好玩的3D操作就是:过渡和动画效果。那么css过渡和css动画的区别是什么?下面本篇文章就来给大家介绍一下CSS中过渡和动画的区别,希望对大家有所帮助。

css过渡和动画的区别:

animation属性类似于transition,他们都是随着时间改变元素的属性值,那么区别是什么?

其主要区别在于:transition需要触发一个事件才会随着时间改变其CSS属性;animation在不需要触发任何事件的情况下,也可以显式的随时间变化来改变元素CSS属性,达到一种动画的效果。

1)动画不需要事件触发,过渡需要。

2)过渡只有一组(两个:开始-结束) 关键帧,动画可以设置多个。

过渡(transition)

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

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

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

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

color: red;

}

p {

transition-property: color;

transition-duration: 2s;

transition-timing-function: linear;

transition-delay: 0;

}

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

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;

}

}

效果:

当然样式除了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-name 和 animation-duration为必须设置的属性;

同样,记得考虑浏览器兼容:@-webkit-keyframes mycanimation {

from {

color: green;

}

to {

color: blue;

}

}

p {

-webkit-animation: my-animation 3s linear infinite;

}

/* -moz-, -ms-, -o- 格式类似 */

更多前端开发知识,请查阅 HTML中文网 !!

html和css动画效果,css过渡和css动画的区别是什么?相关推荐

  1. 【前端实例代码】霓虹灯按钮动画效果悬停2| html CSS特效 惊艳| 前端开发 网页制作 基础入门教程

    b站视频演示效果: [web前端特效源码]霓虹灯按钮动画效果悬停2| html CSS特效 惊艳| 前端开发 网页制作 基础入门教程 效果图: 完整代码: <!DOCTYPE html> ...

  2. js动画与html动画效果,九种原生js动画效果

    在做页面中,多数情况下都会遇到页面上做动画效果,我们大部分做动画的时候都是使用框架来做(比如jquery),这里我介绍下如何让通过原生的js来实现像框架一样的动画效果! 1.匀速动画效果说明:匀速动画 ...

  3. android ui动画效果怎么做,AndroidUI 布局动画-为列表添加布局动画效果

    新建一个Android project ,使MainActivity 继承自 ListActivity: public class MainActivity extends ListActivity ...

  4. Android按下录音录音动画效果 ,自定义录音、播放动画View

    Android按下录音录音动画效果 ,自定义录音.播放动画View https://download.csdn.net/download/abc2522/10327428?spm=1001.2101. ...

  5. html如何自定义一个动画效果,30个纯css动画代码片段和效果演示

    开源代码已经迎来了一个新的web前端时代.初学者和专家都可以通过使用预构建的代码片段节省时间和压力.下面画廊由30个不同的片段与纯CSS创建动画效果. 所有这些代码片段都放在云IDE平台.这些weba ...

  6. 动画效果(过渡,动画)

    1.过渡:css3过渡是元素从一种样式逐渐改变为另一种的效果,css过渡允许你在给定时间内平滑地改变属性值. 1.1.transiton子属性 property:规定应用过渡的CSS属性的名称 取值: ...

  7. vue如何使用原生js写动画效果_深入理解 Vuejs 动画效果

    本文主要归纳在 Vuejs 学习过程中对于 Vuejs 动画效果的各个相关要点.由于本人水平有限,如文中出现错误请多多包涵并指正,感谢.如果需要看更清晰的代码高亮,请跳转至我的个人站点的 Vue 中的 ...

  8. html如何添加加载动画效果,CSS3创建加载动画效果

    加载动画在网页设计中是很常见的.用户们都希望网页加载又快又流畅而不是盯着屏幕苦等,而加载动画能够在内容加载完成前给用户视觉反馈,从而能够吸引用户而不让他们直接放弃继续浏览你的网站. 创建加载效果所需的 ...

  9. html 购物车动画效果,Jquery商品飞入购物车动画效果实例展示

    刚接手一个小玩意,值得收藏分享给大家! <产品图片飞入购物车的jQuery动画> 无标题文档 *{ margin:0; padding:0;} .good-area{ width:200p ...

  10. css3动画效果(旋转,帧动画)

    一.css动画属性 animation是css3的动画属性,也是简写,其中包含以下几种值可配置 默认值:none 0 ease 0 1 normal 值 描述 animation-name 需要绑定到 ...

最新文章

  1. 编码整洁之道:专业程序员的行为准则(英文版)
  2. 后台通过request.setAttribute向前台传值,前台如何去获取其中的对象或属性值
  3. vue-resource安装
  4. 【STM32】HAL库 STM32CubeMX教程五----看门狗(独立看门狗,窗口看门狗)
  5. ROS机器人程序设计(原书第2版)2.4.8 使用参数服务器
  6. zabbix监控哪些东西_监控系统选型,一篇全搞定
  7. Percona Toolkit工具箱的安装与使用--完成复杂的mysql操作。
  8. IDE安装与配置(2018)
  9. 操作系统(1) 操作系统概念
  10. 计算机一级报名照片是几寸的,法考报名照片要求几寸
  11. Trump International Hotel Washington, D.C.宣布跻身猫途鹰“旅行者之选”美国获奖酒店四强之列
  12. UmiJs整合Egg
  13. 电子书管理神器 calibre 5.0.0中文版
  14. Unable to open OMF51 file...
  15. 怎么看空调定时成功_空调定时怎么设置
  16. mysql概念模型中的3种基本联系_在概念模型中,通常用实体联系图表示数据的结构,其 3 个要的元素是( )、( )和( )。_学小易找答案...
  17. C++ 基础概念(二)
  18. 山东大学软件学院数据结构复习题目
  19. spark任务常见错误
  20. 一文速览,118只区块链概念股谁对区块链是真爱?

热门文章

  1. g++链接boost库
  2. typra修改快捷键
  3. Python turtle库的画笔控制说明
  4. python实现秒杀商品的微信自动提醒功能(附代码)
  5. Python高级——协程
  6. Python中的TCP的客户端UDP学习----第一篇博客
  7. 是否应为孩子聘请家教 以及 什么样的家教适合孩子
  8. PRML-系列一之1.2.1
  9. HOG特征(Histogram of Gradient)总结
  10. Kaggle入门——房价预测