css要学动画吗,学习CSS3动画(animation)

CSS3就是出了不少高大上的功能,3D效果、动画、多列等等。今天写篇文章记录怎么一下怎么用CSS3写一个动画。

丑话还得说前头,IE9以及以下版本不支持CSS3动画(如真要实现可以考虑用js,不过估计效果也不太好)。chrome和safafi建议加上前缀-webkit-以向前兼容老版本。

今天简单的做一个动画。

首先,先简单画一个div,然后添上背景图片。

我是demo

.demo{

width: 120px;

height: 120px;

margin: 100px auto;

background: url(img/demo.jpg) no-repeat;

}

一个普通的DIV就出来了 如右:

2538bf58ec77cce61210ffa733818d01.png

接着我们让它动起来

先写一个方法,这个方法描述这个图片该如何运动

@keyframes run_animation{

from {

transform: rotatez(0deg);

}

to {

transform: rotatez(360deg);

}

}

这个animation_run就是这个方法的名字。等下需要把名字关联到相关的元素里。

from是描述动画的起始状态,to是动画的结束状态。

所以这个方法就是让一个元素按顺时针方向转动360度,非常简单。

from to往往不能满足我们日常开发所需,所以还有这种写法

@keyframes run_animation{

0%{

transform:rotatex(0deg);

}

16%{

transform: rotatey(-90deg);

}

33%{

transform: rotatey(-90deg) rotatez(135deg);

}

50%{

transform: rotatey(225deg) rotatez(135deg);

}

66%{

transform: rotatey(135deg) rotatex(135deg);

}

83%{

transform: rotatex(135deg);

}

100%{

transform: rotatex(0deg);

}

}

这种描述让动画可以有更加丰富炫酷的动作。通过百分比来描述每个阶段该元素的动态,0%就是上面说的from,100%就是to。其实这个也很简单对吧~

动画就这么容易的写好了。接下来我们把动画关联到我们的图片上。

.demo{

width: 120px;

height: 120px;

margin: 100px auto;

animation: run_animation 12s linear infinite; /*关联动画名称,定义动画时长,动画播放速度曲线,播放次数*/

background: url(img/demo.jpg) no-repeat 100%;

}

就是这么简单一句代码,图片就能按照我们定义的方法动起来了。

我是demo

要是你现在发现动画没有动,那可能是下面的原因之一:

1.动画名称与@keyframes定义的名称不符;

2.没有定义动画播放时长,默认是0S,即不播放动画。上述代码定义12S;

3.在IE9及以下浏览器运行该代码,IE9及以下不支持CSS3 animation;

4.动画方法定义不对,方法定义的每个阶段中样式都是一样的。像下面这样

@keyframes run_animation{

0%{

transform: rotatez(90deg);

}

50%{

transform: rotatez(90deg);

}

100%{

transform: rotatez(90deg);

}

}

好了,这时候动画应该是动起来了。接着说动画中别的选项:

1.animation-iteration-count:  动画播放次数,想播放几次就写几。我这里用了无限次就是infinite

2.animation-timing-function:动画速度曲线。这个速度曲线有点复杂,涉及到一个贝塞尔函数。不想深入探索贝塞尔就直接用现成的linear、ease、ease-in、ease-out、ease-in-out。要是你懂贝塞尔,可以用cubic-bezier(n,n,n,n),这个比较高大上,我觉得是装逼界的利器。

3.animation-delay:动画可以延时播放,参数也是n S。和animation-duration不一样,animation-duration是动画播放时长。

上面几个属性都可以简写到animation中,就像我上面的栗子一样。

还有逆向播放、暂停这些属性就不说了,有需要可以去看http://www.w3school.com.cn/css3/css3_animation.asp或者

https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Animations/Using_CSS_animations

如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知 ending~

css3学习--css3动画详解一(animation属性)

***介绍的属性并不完全,写的都是我认为容易混淆的难点属性,所以属性会在最后综合案例展示~ 一.Keyframes介绍: Keyframes被称为关键帧,其类似于Flash中的关键帧.在CSS3中其主 ...

CSS3 动画 animation和@keyframes

CSS3 @keyframes 规则 如需在 CSS3 中创建动画,您需要学习 @keyframes 规则. @keyframes 规则用于创建动画.在 @keyframes 中规定某项 CSS 样式 ...

CSS3 动画animation

关键帧 什么是关键帧.一如上面对Flash原理的描述一样,我们知道动画其实由许多静态画面组成,第一个这样的静态画面可以表述为一帧.其中关键帧是在动画过程中体现了物理明显变化的那些帧. 比如之前的例子中 ...

css3 动画(animation)-简单入门

css3之动画(animation) css3中我们可以使用动画,由于取代以前的gif图片,flash动画,以及部分javascript代码(相信有很多同学都用过jquery中的animate方法来做 ...

CSS3动画animation认识,animate.css的使用

CSS动画 可以取代js动画 在移动端会更加流畅! 下面是一个的绘制太阳系各大行星运行轨迹笔记,可以自学参考! -------------------------------------------- ...

CSS3 动画Animation的8大属性

animation复合属性.检索或设置对象所应用的动画特效. 如果有多个属性值时以","隔开,适用于所有元素,包含伪对象:after和:before 1.animation-nam ...

css3动画animation

动画:animation   animations这物似乎还是只在webkit,moz核心的浏览器上起作用

str_翻转字符串

1. 给一个句子,翻转每个单词,单词内部不翻转 $str = "dog loves pig"; $ret = turnSentence($str); var_dump($ret); ...

C#调用WebService实例和开发(转)

1.1.Web Service基本概念 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求, ...

ANR的一个实例分析

ANR是android经常出的超时提示,以前看过一个帖子,内容是mediaplayer在release的时候出的ANR,作者也是出了方法,什么加handler之类的. 最后都么有解决,咱们先看看那位同 ...

vs2008中xlslib与libxls库的编译及使用

C++用来操作Excel的方法很多,但是涉及到跨平台,同时又要对Excel的读写操作兼顾,而且免费的库,那应该是要用xlslib和libxls了.由于技术比较菜,折腾这个折腾了一个星期了.最开始是使用 ...

Page.ClientScript.RegisterStartupScript用法小结

使用类型.键.脚本文本和指示是否添加脚本标记的布尔值向 Page 对象注册启动脚本. 参数 type 要注册的启动脚本的类型. key 要注册的启动脚本的键. script 要注册的启动脚本文本. a ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值