css3在原来的基础上增加了变形和动画相关的属性,动画三兄弟:transform、transition和animation,通过使用这三个属性可以达到很炫酷的效果。需要注意的是这三个属性都是css3新增的属性,各大浏览器支持方面还不是特别好,使用时要特别注意浏览器的兼容性。
浏览器支持情况:
Internet Explorer 10、Firefox、Opera 支持 transform 属性。
Internet Explorer 9 支持替代的 -ms-transform 属性(仅适用于 2D 转换)。
Safari 和 Chrome 支持替代的 -webkit-transform 属性(3D 和 2D 转换)。
Opera 只支持 2D 转换。
2D transform变换方法
函数 | 描述 |
---|---|
translate(x,y) | 定义 2D 转换,沿着 X 和 Y 轴移动元素 |
rotate(angle) | 定义 2D 旋转,在参数中规定角度 |
scale(x,y) | 定义 2D 缩放转换,改变元素的宽度和高度 |
skew(x-angle,y-angle) | 定义 2D 倾斜转换,沿着 X 和 Y 轴 |
matrix(n,n,n,n,n,n) | 定义 2D 转换,使用六个值的矩阵 |
下面是上面方法的演示:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform 2D演示</title>
<style type="text/css"> #container{ width: 700px; height: 120px; border: 1px solid blue; margin: 20px auto; padding: 20px 20px; } #div1 ,#div2, #div3, #div4{ height: 100px; width: 100px; border: 1px dashed red; display: inline-block; } #div1 div{ height: 100px; width: 100px; background: #63F7ED; transform:translate(20px,10px); /* W3C标准 */ -ms-transform:translate(20px,10px); /* IE 9 */ -moz-transform:translate(20px,10px); /* Firefox */ -webkit-transform:translate(20px,10px); /* Safari 和 Chrome */ -o-transform:translate(20px,10px); /* Opera */ } #div2{margin-left: 50px;} #div2 div{ height: 100px; width: 100px; background: #63F7ED; transform:rotate(45deg); /* W3C标准 */ -ms-transform:rotate(45deg); /* IE 9 */ -moz-transform:rotate(45deg); /* Firefox */ -webkit-transform:rotate(45deg); /* Safari 和 Chrome */ -o-transform:rotate(45deg); /* Opera */ } #div3{margin-left: 100px;} #div3 div{ height: 100px; width: 100px; background: #63F7ED; transform:scale(2,0.5); /* W3C标准 */ -ms-transform:scale(2,0.5); /* IE 9 */ -moz-transform:scale(2,0.5); /* Firefox */ -webkit-transform:scale(2,0.5); /* Safari 和 Chrome */ -o-transform:scale(2,0.5); /* Opera */ } #div4{margin-left: 100px;} #div4 div{ height: 100px; width: 100px; background: #63F7ED; transform:skew(30deg,-20deg); /* W3C标准 */ -ms-transform:skew(30deg,-20deg); /* IE 9 */ -moz-transform:skew(30deg,-20deg); /* Firefox */ -webkit-transform:skew(30deg,-20deg); /* Safari 和 Chrome */ -o-transform:skew(30deg,-20deg); /* Opera */ } </style>
</head>
<body>
<div id="container">
<div id="div1">
<div>translate</div>
</div>
<div id="div2">
<div>rotate</div>
</div>
<div id="div3">
<div>scale</div>
</div>
<div id="div4">
<div>skew</div>
</div>
</div>
</body>
</html>
效果如下:
transform-origin 属性
前面我们提到的transform的方法都是基于元素的中心来变换的,也就是元素变换的基点默认是元素的中心。但是有时候我们需要在不同的位置对元素进行这些操作,那么我们就可以使用transform-origin来对元素进行基点位置改变。该属性可以接收三个参数:
transform-origin: x-axis y-axis z-axis;
我们可以设置基点来与之前的transform图形进行对比:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform-origin演示</title>
<style type="text/css"> *{ margin: 0; padding: 0; } #container{ width: 800px; height: 150px; border: 1px solid blue; margin: 20px auto; padding: 20px 20px; } #div1 ,#div2, #div3, #div4{ height: 100px; width: 100px; border: 1px dashed red; display: inline-block; } #div1 div{ height: 100px; width: 100px; background: #63F7ED; transform:translate(20px,10px); /* W3C标准 */ -ms-transform:translate(20px,10px); /* IE 9 */ -moz-transform:translate(20px,10px); /* Firefox */ -webkit-transform:translate(20px,10px); /* Safari 和 Chrome */ -o-transform:translate(20px,10px); /* Opera */ transform-origin:left top; /* W3C标准 */ -ms-transform-origin:left top; /* IE 9 */ -moz-transform-origin:left top; /* Firefox */ -webkit-transform-origin:left top; /* Safari 和 Chrome */ -o-transform-origin:left top; /* Opera */ } #div2{margin-left: 100px;} #div2 div{ height: 100px; width: 100px; background: #63F7ED; transform:rotate(45deg); /* W3C标准 */ -ms-transform:rotate(45deg); /* IE 9 */ -moz-transform:rotate(45deg); /* Firefox */ -webkit-transform:rotate(45deg); /* Safari 和 Chrome */ -o-transform:rotate(45deg); /* Opera */ transform-origin:0% 0%; /* W3C标准 */ -ms-transform-origin:0% 0%; /* IE 9 */ -moz-transform-origin:0% 0%; /* Firefox */ -webkit-transform-origin:0% 0%; /*Safari 和 Chrome */ -o-transform-origin:0% 0%; /* Opera */ } #div3{margin-left: 50px;} #div3 div{ height: 100px; width: 100px; background: #63F7ED; transform:scale(2,0.5); /* W3C标准 */ -ms-transform:scale(2,0.5); /* IE 9 */ -moz-transform:scale(2,0.5); /* Firefox */ -webkit-transform:scale(2,0.5); /* Safari 和 Chrome */ -o-transform:scale(2,0.5); /* Opera */ transform-origin:center top; /* W3C标准 */ -ms-transform-origin:center top; /* IE 9 */ -moz-transform-origin:center top; /* Firefox */ -webkit-transform-origin:center top; /* Safari 和 Chrome */ -o-transform-origin:center top; } #div4{margin-left: 150px;} #div4 div{ height: 100px; width: 100px; background: #63F7ED; transform:skew(30deg,-20deg); /* W3C标准 */ -ms-transform:skew(30deg,-20deg); /* IE 9 */ -moz-transform:skew(30deg,-20deg); /* Firefox */ -webkit-transform:skew(30deg,-20deg); /* Safari 和 Chrome */ -o-transform:skew(30deg,-20deg); /* Opera */ transform-origin:100% 100%; /* W3C标准 */ -ms-transform-origin:100% 100%; /* IE 9 */ -moz-transform-origin:100% 100%; /* Firefox */ -webkit-transform-origin:100% 100%; /* Safari 和 Chrome */ -o-transform-origin:100% 100%; } </style>
</head>
<body>
<div id="container">
<div id="div1">
<div>translate(基点为(left top)</div>
</div>
<div id="div2">
<div>rotate(基点为(0%, 0%)</div>
</div>
<div id="div3">
<div>scale(基点为(center, top)</div>
</div>
<div id="div4">
<div>skew(基点为(100%, 100%)</div>
</div>
</div>
</body>
</html>
对比发现:translate()方法与之前的没有区别,其他三个方法基点改变了,图形变形效果也有所变化。
3D transform变换方法
Internet Explorer 10 和 Firefox 支持 3D 转换.
Chrome 和 Safari 必须添加前缀 -webkit-.
Opera 还不支持 3D 转换(支持 2D 转换 ).
三维变换使用基于二维变换的相同属性。CSS3中的3D变换主要包括以下几种功能函数:
还有以下几个转换属性:
目前各大主流浏览器对transform 3d属性的兼容性还不是特别好,感兴趣的读者可以自行深入了解。下面我们介绍几个常用的功能方法:
rotateX()方法,围绕其在一个给定度数X轴旋转的元素;
rotateY()方法,围绕其在一个给定度数Y轴旋转的元素;
rotateZ()方法,围绕其在一个给定度数Z轴旋转的元素。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform 3d </title>
<style type="text/css"> *{ margin: 0; padding: 0; } #container{ width: 440px; height: 120px; border: 1px solid blue; margin: 20px auto; padding: 20px 20px; } #div1 ,#div2, #div3, #div4{ height: 100px; width: 100px; border: 1px dashed red; display: inline-block; } #div1 div{ height: 100px; width: 100px; background: #63F7ED; transform:rotateX(45deg); /* W3C标准 */ -webkit-transform:rotateX(45deg)); /* Safari 和 Chrome */ } #div2{margin-left: 50px;} #div2 div{ height: 100px; width: 100px; background: #63F7ED; transform:rotateY(45deg); /* W3C标准 */ -webkit-transform:rotateY(45deg)); /* Safari 和 Chrome */ } #div3{margin-left: 50px;} #div3 div{ height: 100px; width: 100px; background: #63F7ED; transform:rotateZ(45deg); /* W3C标准 */ -webkit-transform:rotateZ(45deg)); /* Safari 和 Chrome */ } </style>
</head>
<body>
<div id="container">
<div id="div1">
<div>rotateX(45deg)</div>
</div>
<div id="div2">
<div>rotateY(45deg)</div>
</div>
<div id="div3">
<div>rotateZ(45deg)</div>
</div>
</div>
</body>
</html>
W3C标准中对css3的transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变CSS的属性值。”
transition属性的值包括以下四个:
浏览器兼容性
Internet Explorer 9 以及更早的版本,不支持 transition 属性。
Internet Explorer 10, Firefox, Opera 和 Chrome支持transition 属性。Chrome 25 以及更早的版本以及Safari 需要前缀 -webkit-。
下面还是以实例来说明transition的用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transition演示1</title>
<style type="text/css"> .animated_div { margin: 100px auto; width:100px; height:60px; background:#92B901; /*简写属性*/ -webkit-transition:-webkit-transform 1s,opacity 1s,background 1s,width 1s,height 1s,font-size 1s; /* Safari */ /*每个属性分开写*/ transition-property:width,height,transform,background,opacity; transition-duration:1s,1s,1s,1s,1s,1s; -webkit-border-radius:5px; border-radius:5px; opacity:0.4; } .animated_div:hover { -moz-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); transform: rotate(360deg); opacity:1; background:#1ec7e6; width:200px; height:120px; } </style>
</head>
<body>
<div class="animated_div"></div>
</body>
</html>
上述代码当鼠标移到div上时,CSS属性:width,height,transform,background,opacity都发生渐变过渡效果。最终css样式变成.animated_div
里定义的样式,过渡过程大致如下:
再给一个网上的嫦娥奔月的示例,要求:当鼠标移到图片上时,嫦娥出现,移开时嫦娥消失
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>transition演示2</title>
<style type="text/css"> body{ color: #fff; background:#000; } .change{ display:block; width:400px; height:400px; background:url(http://p3.qhimg.com/t0134c65e59012a1257.png) no-repeat center; background-size:cover; border:1em solid rgba(255,255,255,.8); margin:50px auto; } .change img{ display:block; width:300px; height:284px; opacity:0; -webkit-transform:translate(-100px,-100px); transform:translate(-100px,-100px); -webkit-transition:opacity 1s ease-in-out 0.5s,-webkit-transform 1s ease-in-out; transition: opacity 1s ease-in-out 0.5s,transform 1s ease-in-out; } .change:hover img{ -webkit-transform:translate(0px,0px); transform:translate(0px,0px); opacity:1; } </style>
</head>
<body>
<a href="http://image.haosou.com/i?q=%E5%AB%A6%E5%A8%A5png&src=tab_www" class="change " target="_blank">
<img src="http://p4.qhimg.com/t0160e6a92121691e22.png" alt="" />
</a>
</body>
</html>
为了使嫦娥有飘入飘出的效果,设置了transform属性,配合opacity属性,加入过渡效果就能达到效果:
要使用animation动画,先要熟悉一下keyframes,Keyframes的语法规则:命名是由”@keyframes”开头,后面紧接着是这个“动画的名称”加上一对花括号“{}”,括号中就是一些不同时间段样式规则。不同关键帧是通过from(相当于0%)、to(相当于100%)或百分比来表示(为了得到最佳的浏览器支持,建议使用百分比),如下定义一个简单的动画:
@keyframes myfirst /*定义动画名*/ {
0% {background:red; left:0px; top:0px;} /*定义起始帧样式,0%可以换成from*/
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;} /*定义结束帧样式,100%可以换成to*/
}
@keyframes定义好了,要使其能发挥效果,必须通过animation把它绑定到一个选择器,否则动画不会有任何效果。下面列出了animation的属性:
属性 | 描述 | 取值 |
---|---|---|
animation | 所有动画属性的简写属性,除了 animation-play-state 属性 | |
animation-name | 规定 @keyframes 动画的名称 | |
animation-duration | 规定动画完成一个周期所花费的秒或毫秒 | 默认是 0 |
animation-timing-function | 规定动画的速度曲线 | 默认是 “ease” |
animation-delay | 规定动画何时开始 | 默认是 0 |
animation-iteration-count | 规定动画被播放的次数 | 默认是 1(infinite:无限次 |
animation-direction | 规定动画是否在下一周期逆向地播放 | 默认是 “normal”(reverse:反向播放;alternate:奇数次正向播放,偶数次反向播放;alternate-reverse:奇数次反向播放,偶数次正向播放。) |
animation-play-state | 规定动画是否正在运行或暂停 | 默认是 “running”(paused:暂停动画) |
下面设置上述的所有属性
animation-name:myfirst;
animation-duration:5s;
animation-timing-function:linear;
animation-delay:1s;
animation-iteration-count:infinite;
animation-direction:alternate;
animation-play-state:running;
上述所有代码可以如下简写:
animation:myfirst 5s linear 2s infinite alternate;
animation-play-state:running;
浏览器兼容性
Internet Explorer 10、Firefox 以及 Opera 支持 @keyframes 规则和 animation 属性。
Chrome 和 Safari 需要前缀 -webkit-。
注意:Internet Explorer 9,以及更早的版本,不支持 @keyframe 规则或 animation 属性。
下面给出上面介绍的关于keyframes和animation属性的完整代码示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>animation演示</title>
<style> div { width:100px; height:100px; background:red; position:relative; animation-name:myfirst; animation-duration:5s; animation-timing-function:linear; animation-delay:1s; 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:1s; -webkit-animation-iteration-count:infinite; -webkit-animation-direction:alternate; -webkit-animation-play-state:running; } @keyframes myfirst /*定义动画名*/ { 0% {background:red; left:0px; top:0px;} /*定义起始帧样式,0%相当于from*/ 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;} /*定义结束帧样式,100%相当于to*/ } @-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>该实例在 Internet Explorer 9 及更早 IE 版本是无效的。</p>
<div></div>
</body>
</html>
上面代码演示了一个正方形沿着一个正方形轨迹运动,基数次按正方向运动,偶数次按反方向运动,运动过程中还带有颜色变化。具体效果,读者可以自行运行代码观察。
至此,关于CSS3中变形和动画相关的属性介绍完了,博文中只介绍了属性的基本用法,这三个属性的功能很强大,读者可以根据自己的喜好设计出完美的效果。