国外测试网站:http://codepen.io/;
transform(变形)
CSS3中可以通过transform属性修改元素的变形、旋转、缩放、倾斜特性,在CSS3中transform主要包括以下几种:旋转rotate、倾斜skew、缩放scale和移动translate以及矩阵变形matrix
transform-origin的取值可以是top, bottom, left, right, center, 或百分比,或长度值
参数:
rotate(旋转)
可以通过rotate使元素旋转一定的度数
transform:rotate(30deg);
顺时针旋转一定角度, 单位是角度deg(degree)
旋转之后元素仍占据原来位置,实际上所有的transform都是这样,缩放、位移等都不会改变元素占据的位置
元素旋转的的基点默认是中心(坐标轴原点),可以通过transform-origin属性改变
transform:rotate(30deg);
transform-origin: 0% 0%;
transform-origin的取值可以是top, bottom, left, right, center, 或百分比,或长度值
transform-origin属性对下面介绍的transform都有作用
translate(位移)
可以通过translate使元素平移
transform:translate(x,y);
例子
transform:translate(200px,150px);
也可以简单只移动一个坐标
transform:translateX(100px);
transform:translateY(100px);
scale(缩放)
可以通过scale使元素缩放一定的比例,和translate类似,也有三个方法
scale(x,y) /*使元素水平方向和垂直方向同时缩放*/
scaleX(x) /*元素仅水平方向缩放*/
scaleY(y) /*元素仅垂直方向缩放*/
transform:scale(2, 0.5);
transform:scaleY(0.3);
transform:scaleY(2);
transform:scale(3);
skew(倾斜)
可以通过skew使元素扭曲一定的度数,和上面一样也有三中类似的用法
transform:skew(10deg, 20deg);
transform:skewX(10deg);
transform:skewY(10deg);
transform:skew(10deg);
transform应用,时钟完整代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
*{
margin:0;
padding:0;
}
.clock{
background: #000;
width:200px;
height: 200px;
margin:0 auto;
border-radius: 50%;
position: relative;
}
.circle{
position: absolute;
width:20px;
height: 20px;
border-radius: 50%;
background: #fff;
left: 50%;
top:50%;
margin-top:-10px;
margin-left: -10px;
z-index: 50;
}
.hour-line{
position: absolute;
width:40px;
height: 10px;
background:red;
left: 50%;
top:50%;
margin-top:-5px;
border-radius: 5px;
transform-origin:0 50%;
z-index: 1;
}
.min-line{
position: absolute;
width:50px;
height: 8px;
background:#454;
left: 50%;
top:50%;
margin-top:4px;
border-radius: 5px;
transform-origin:0 50%;
z-index: 1;
}
.sec-line{
position: absolute;
width:60px;
height: 4px;
background:#8ac;
left: 50%;
top:50%;
margin-top:-2px;
border-radius: 1px;
transform-origin:0 50%;
z-index: 1;
}
.hours div{
position: absolute;
width: 20px;
height: 2px;
background:red;
left: 50%;
top:50%;
margin-top:-1px;
margin-left:-10px;
border-radius: 1px;
}
.mins div{
position: absolute;
width:8px;
height: 2px;
background:red;
left: 50%;
top:50%;
margin-top:-1px;
margin-left:-4px;
border-radius: 1px;
}
</style>
</head>
<body>
<div class="clock">
<!-- 圆心 -->
<div class="circle"></div>
<!-- 指针 -->
<div class="hour-line"></div>
<div class="min-line"></div>
<div class="sec-line"></div>
<!-- 刻度 -->
<div class="hours"></div>
<div class="mins"></div>
</div>
<script>
var hours=document.querySelector('.hours');
var mins=document.querySelector('.mins');
//生成时间刻度
var hourStr='';
for(var i=0;i<12;i++){
hourStr+='<div style="transform: rotate('+(-90+i*30)+'deg) translate(85px);"></div>'
}
hours.innerHTML=hourStr;
var minStr='';
for(var i=0;i<60;i++){
minStr+='<div style="transform: rotate('+(-90+i*6)+'deg) translate(90px);"></div>'
}
mins.innerHTML=minStr;
//获取时间指针
var hourLine=document.querySelector('.hour-line');
var minLine=document.querySelector('.min-line');
var secLine=document.querySelector('.sec-line');
//封装指针旋转角度函数
function drawClock(){
//获取当前时间
var now=new Date();
var hour=now.getHours();
var min=now.getMinutes();
var sec=now.getSeconds();
hourLine.style.transform='rotate('+(-90+hour*30+(min/60)*6)+'deg)';
minLine.style.transform='rotate('+(-90+min*6+(sec/60)*6)+'deg)';
secLine.style.transform='rotate('+(-90+sec*6)+'deg)';
}
drawClock();
//开启定时器
setInterval(function(){
drawClock();
}, 1000);
</script>
</body>
</html>
transform 3D 效果
相关函数
旋转 rotateX() rotatY() rotateZ()
位移 translateZ()
缩放 scaleZ()
perspective
在父级设置睛生perspective:500px;
perspective属性的值决定了3D效果的强烈程度,可以认为是观察者到页面的距离。值越大距离越远,视觉上的3D效果就会相应的减弱。perspective: 2000px; 会产生一个好像我们使用望远镜看远方物体的3D效果,perspective: 100px;会产生一个小昆虫看大象的效果。
perspective-origin //设置消失的位置
在父级设置perspective-origin: 0 0;
定义了消失点的位置,如当你沿着铁路线去看两条铁轨,沿着公路线去看两边排列整齐的树木时,两条平行的铁轨或两排树木连线交与很远很远的某一点,这点在透视图中叫做消失点。
backface-visibility
子元素上设置backface-visibility:hidden;
backface-visibility属性指定当元素背面朝向观察者时是否可见。元素的背面总是透明的,当其朝向观察者时,显示正面的镜像。
在某些情况下,我们不希望元素内容在背面可见,比如实现翻牌效果。
transform-style
在父级设置transform-style: preserve-3d;
transform-style属性指定了,该元素的子元素是(看起来)位于三维空间内,还是在该元素所在的平面内被扁平化。
如果被扁平化,则子元素不会独立的存在于三维空间。
在元素本身设置旋转的中心点transform-origin: center center 100px;
正方体
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.cube{
position: relative;
width:200px;
height: 200px;
margin:200px auto;
perspective:4000px;
transition: all 1s;
transform-style: preserve-3d;/*使里面的div有3D效果*/
transform-origin: center center 100px;
transform: rotateY(30deg);/*旋转*/
transform: skew(30deg);/*倾斜*/
}
.cube:hover{
transform: rotateY(180deg);
}
.cube div{
position: absolute;
width:200px;
height: 200px;
color: #c3c;
font-size: 60px;
text-align: center;
line-height: 200px;
}
.cube div:nth-child(1){
transform-origin:right center;
transform:translateX(-200px) rotateY(90deg);
background:rgba(23,222,10,.6);
}
.cube div:nth-child(2){
transform-origin:left center;
transform:translateX(200px) rotateY(-90deg);
background:rgba(23,11,10,.6);
}
.cube div:nth-child(3){
transform-origin:bottom center;
transform:translateY(-200px) rotateX(-90deg);
background:rgba(23,66,10,.6);
}
.cube div:nth-child(4){
transform-origin:top center;
transform:translateY(200px) rotateX(90deg);
background:rgba(23,123,10,.6);
}
.cube div:nth-child(5){
transform:translateZ(200px);
background:rgba(23,211,10,.6);
}
.cube div:nth-child(6){
background:rgba(23,45,11,.6);
}
</style>
</head>
<body>
<div class="cube">
<div class="side-1">1</div>
<div class="side-2">2</div>
<div class="side-3">3</div>
<div class="side-4">4</div>
<div class="side-5">5</div>
<div class="side-6">6</div>
</div>
</body>
</html>