简单介绍CSS3中的transform的使用方法
transform属性分为2D转换和3D转换
一,转换(transform)是CSS3中具有颠覆性的特征之一,可以实现元素的位移,旋转,缩放等效果。分为两种转换,分别是2D以及3D转换效果。
转换可以简单理解为的变形,其主要效果有三种:
- 移动:translate;
- 旋转:rotate;
- 缩放:scale;
1,2D转换前置知识:
了解二维坐标系
x轴水平向右,y轴垂直向下。
2,2D转换的几种变换方法:
- translate() 位移
- rotate() 旋转
- scale() 缩放
translate()位移方法 ,有两个参数(x轴平移距离,y轴平移距离),从当前元素位置移动。
位移:transform:translate(水平移动距离,垂直移动距离 ) 中间用逗号隔开
取值:数字px /百分比(基于盒子自身的百分比)
技巧:如果只给一个值,表示x轴方向移动
想单独给某个方向移动:translate X() / translate Y()
特点:会增大盒子层级,没有脱标,对行内元素不起效果
使用方法:
div{
width:100px;
height:100px;
background-color: aqua;
transform: translate(50px,60px);
}
水平方向移动50px,垂直方向移动60px。效果如图所示:(图中为方便看出效果,所以使用两种颜色作为前后对比,以下都是)。当值为负数时,就是沿着该方向的反方向移动。
rotate()旋转方法给定度数顺时针旋转的元素。允许负值,这样是元素逆时针旋转
旋转:transform:rotate(角度)注意:单位是deg,一圈是360deg
取值:单位是deg,正负均可
div{
width:100px;
height:100px;
background-color: aqua;
transform: rotate(30deg);
}
前后效果对比:
scale()元素宽高增加或减少的大小,类如transform: scale(1,2)宽不变,高放大两倍。
数字大于1表示放大,小于1表示缩小,小于1表示不变,只写一个值,表示x轴和y轴等比例缩放
div{
transform: scale(1,2);
}
二,空间转换(3D转换)
定义:由x,y,z轴组成立体空间,z轴与视线方向相同(正值指向用户本身)
位移:transform:translate3d(x,y,z),因为是空间转换,后面需要填写3d,单独写需要把三个坐标轴单独写
透视效果:perspective :值(取值一般400-1200px),属性加给父级
z轴是视线方向,产生近大远小
空间旋转
transform:rotateZ(值deg )
带了什么值表示沿着哪个值执行指令
transform:rotateX(值deg ),加上透视属性,像手心一样
transform:rotateY(值deg ),像开门一样
立体呈现:transform-style:preseve-3d
给父元素添加属性,按需求设置盒子的位置(位移或旋转),用子绝父相定位,在选择一个盒子往前拉(transform:translate),
作用:使子元素处于真正的3d空间
更多推荐
所有评论(0)