CSS3 动画

    CSS3,我们可以创建动画,它可以取代许多网页动画图像,Flash动画,和JAVAScript

CSS3 @keyframes 规则

   @keyframes规则是创建动画。 @keyframes规则内指定一个CSS样式和动画将逐步从目前的样式更改为新的样式。

浏览器支持

   表格中的数字表示支持该属性的第一个浏览器版本号。

   紧跟在 -webkit-, -ms- 或 -moz- 前的数字为支持该前缀属性的第一个浏览器版本号。

 

实例

@keyframes myfirst{  

    from {background: red;}  

    to {background: yellow;}

}



@-webkit-keyframes myfirst /* Safari 与 Chrome */{

from {background: red;}  

    to {background: yellow;}

}

 

CSS3 动画

 

    当在 @keyframes 创建动画,把它绑定到一个选择器,否则动画不会有任何效果。

   指定至少这两个CSS3的动画属性绑定向一个选择器:

   ·规定动画的名称

   ·规定动画的时长

<!DOCTYPE html>
<html>
	<head>
		<title>自学教程(如约智惠.com)</title>
		<meta charset="utf-8">
		<style>
			div
			{
				width:100px;
				height:100px;
				background:red;
				animation:myfirst 5s;
				-webkit-animation:myfirst 5s;
			}

			@keyframes myfirst {
				from {background:red;}
				to {background:yellow;}
			}
			
			@-webkit-keyframes myfirst /* Safari and Chrome */
			{
				from {background:red;}
				to {background:yellow;}
			}
				
		</style>
	</head>
	<body >
		<p><b>注意:</b> 该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
		<div></div>
	</body>
</html>

 

CSS3 动画原理

 

   动画是使元素从一种样式逐渐变化为另一种样式的效果。

   您可以改变任意多的样式任意多的次数。

   请用百分比来规定变化发生的时间,或用关键词 "from" 和 "to",等同于 0% 和 100%。

   0% 是动画的开始,100% 是动画的完成。

   为了得到最佳的浏览器支持,您应该始终定义 0% 和 100% 选择器。

<!DOCTYPE html>
<html>
	<head>
		<title>自学教程(如约智惠.com)</title>
		<meta charset="utf-8">
		<style>
			div
			{
				width:100px;
				height:100px;
				background:red;
				animation:myfirst 5s;
				-moz-animation:myfirst 5s; /* Firefox */
				-webkit-animation:myfirst 5s; /* Safari and Chrome */
				-o-animation:myfirst 5s; /* Opera */
			}

			@keyframes myfirst
			{
				0%   {background:red;}
				25%  {background:yellow;}
				50%  {background:blue;}
				100% {background:green;}
			}

			@-moz-keyframes myfirst /* Firefox */
			{
				0%   {background:red;}
				25%  {background:yellow;}
				50%  {background:blue;}
				100% {background:green;}
			}

			@-webkit-keyframes myfirst /* Safari and Chrome */
			{
				0%   {background:red;}
				25%  {background:yellow;}
				50%  {background:blue;}
				100% {background:green;}
			}

			@-o-keyframes myfirst /* Opera */
			{
				0%   {background:red;}
				25%  {background:yellow;}
				50%  {background:blue;}
				100% {background:green;}
			}
		</style>
	</head>
	<body >
		<div></div>
		<p><b>注释:</b>当动画完成时,会变回初始的样式。</p>
		<p><b>注意:</b> 该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
	</body>
</html>
<!DOCTYPE html>
<html>
	<head>
		<title>自学教程(如约智惠.com)</title>
		<meta charset="utf-8">
		<style>
			div
			{
				width:100px;
				height:100px;
				background:red;
				position:relative;
				animation:myfirst 5s;
				-webkit-animation:myfirst 5s; /* Safari and Chrome */
			}

			@keyframes myfirst
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}

			@-webkit-keyframes myfirst /* Safari and Chrome */
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}
		</style>
	</head>
	<body >
		<p><b>注意:</b> 该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
		<div></div>
	</body>
</html>

实例

 

<!DOCTYPE html>
<html>
	<head>
		<title>自学教程(如约智惠.com)</title>
		<meta charset="utf-8">
		<style>
			div
			{
				width:100px;
				height:100px;
				background:red;
				position:relative;
				animation-name:myfirst;
				animation-duration:5s;
				animation-timing-function:linear;
				animation-delay:2s;
				animation-iteration-count:infinite;
				animation-direction:alternate;
				animation-play-state:running;
				/* Safari and Chrome: */
				-webkit-animation-name:myfirst;
				-webkit-animation-duration:5s;
				-webkit-animation-timing-function:linear;
				-webkit-animation-delay:2s;
				-webkit-animation-iteration-count:infinite;
				-webkit-animation-direction:alternate;
				-webkit-animation-play-state:running;
			}

			@keyframes myfirst
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}

			@-webkit-keyframes myfirst /* Safari and Chrome */
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}
		</style>
	</head>
	<body >
		<p><b>注意:</b> 该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
		<div></div>
	</body>
</html>
<!DOCTYPE html>
<html>
	<head>
		<title>自学教程(如约智惠.com)</title>
		<meta charset="utf-8">
		<style>
			div
			{
				width:100px;
				height:100px;
				background:red;
				position:relative;
				animation:myfirst 5s linear 2s infinite alternate;
				/* Firefox: */
				-moz-animation:myfirst 5s linear 2s infinite alternate;
				/* Safari and Chrome: */
				-webkit-animation:myfirst 5s linear 2s infinite alternate;
				/* Opera: */
				-o-animation:myfirst 5s linear 2s infinite alternate;
			}

			@keyframes myfirst
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}

			@-webkit-keyframes myfirst /* Safari and Chrome */
			{
				0%   {background:red; left:0px; top:0px;}
				25%  {background:yellow; left:200px; top:0px;}
				50%  {background:blue; left:200px; top:200px;}
				75%  {background:green; left:0px; top:200px;}
				100% {background:red; left:0px; top:0px;}
			}
		</style>
	</head>
	<body >
		<p><b>注意:</b> 该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
		<div></div>
	</body>
</html>

 

 

 

 

 

 

 

CSS3的动画属性

下面的表格列出了 @keyframes 规则和所有动画属性:

属性描述CSS
@keyframes规定动画。3
animation所有动画属性的简写属性,除了 animation-play-state 属性。3
animation-name规定 @keyframes 动画的名称。3
animation-duration规定动画完成一个周期所花费的秒或毫秒。默认是 0。3
animation-timing-function规定动画的速度曲线。默认是 "ease"。3
animation-delay规定动画何时开始。默认是 0。3
animation-iteration-count规定动画被播放的次数。默认是 1。3
animation-direction规定动画是否在下一周期逆向地播放。默认是 "normal"。3
animation-play-state规定动画是否正在运行或暂停。默认是 "running"。3

参考:

https://www.yuque.com/docs/share/239b37da-705d-40cb-be5d-197473b51da6

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值