组团学

CSS3新特性-2D变形 transform

阅读 (377)

transform是CSS3中具有颠覆性的特征之一,可以实现元素的位移、旋转、倾斜、缩放,甚至支持矩阵方式,配合过渡和即将学习的动画知识,可以取代大量之前只能靠Flash才可以实现的效果。

一、移动 translate(x, y)

  • 说明

    translate 移动平移的意思,可以改变元素的位置,x、y可为负值;

    translate(x,y)水平方向和垂直方向同时移动(也就是X轴和Y轴同时移动)
    translateX(x)仅水平方向移动(X轴移动)
    translateY(Y)仅垂直方向移动(Y轴移动)

1498443715586.png

  • 语法

    { transform:translate(50px,50px); /*将文字或图像在水平方向和垂直方向上分别移动50像素*/ }
  • 示例: 实现定位盒子的水平垂直居中

    .box { width: 500px; height: 400px; background: pink; position: absolute; left:50%; top:50%; transform:translate(-50%,-50%); /* 移动自己的一半 */ }
  • 注意

    1. 沿着X和Y轴移动

    2. translate最大的优点:不会影响其他元素的位置(有别于定位和设置外边距)

    3. translate中的百分比是相对于元素本身

二、缩放 scale(x, y)

  • 说明

    可以对元素进行水平和垂直方向的缩放

    1498444645795.png

  • 语法

    transform:scale(0.8,1);/*使该元素在水平方向上缩小了20%,垂直方向上不缩放*/

    scale(X,Y)使元素水平方向和垂直方向同时缩放(也就是X轴和Y轴同时缩放)
    scaleX(x)元素仅水平方向缩放(X轴缩放)
    scaleY(y)元素仅垂直方向缩放(Y轴缩放)

  • 注意

    scale()的取值默认的值为1,当值设置为0.01到0.99之间的任何值,作用使一个元素缩小;而任何大于或等于1.01的值,作用是让元素放大

三、旋转 rotate(deg)

  • 说明

    可以对元素进行旋转,正值为顺时针,负值为逆时针;

1498443651293.png

  • 语法

    transform:rotate(45deg);
  • 注意

    单位是 deg 度数

四、调整转换变形的原点 transform-origin

  • 说明

    可以调整元素转换变形的原点

1498443912530.png

div{transform-origin: left top;transform: rotate(45deg); } /* 改变元素原点到左上角,然后进行顺时旋转45度 */

如果是4个角,可以用 left top这些,如果想要精确的位置, 可以用 px 像素。

div{transform-origin: 10px 10px;transform: rotate(45deg); } /* 改变元素原点到x 为10 y 为10,然后进行顺时旋转45度 */

案例旋转

div { width: 250px; height: 170px; border: 1px solid pink; margin: 200px auto; position: relative; } div img { width: 100%; height: 100%; position: absolute; top: 0; left: 0; transition: all 0.6s; transform-origin: top right; } div:hover img:nth-child(1) { /* 鼠标经过div 第一张图片旋转 */ transform: rotate(60deg); } div:hover img:nth-child(2) { transform: rotate(120deg); } div:hover img:nth-child(3) { transform: rotate(180deg); } div:hover img:nth-child(4) { transform: rotate(240deg); } div:hover img:nth-child(5) { transform: rotate(300deg); } div:hover img:nth-child(6) { transform: rotate(360deg); }

五、倾斜 skew(deg, deg)

1498443827389.png

transform:skew(30deg,0deg); /*把元素水平方向上倾斜30度,处置方向保持不变*/

可以使元素按一定的角度进行倾斜,可为负值,第二个参数不写默认为0。

六、2D转换综合写法

  • 说明

    同时使用多个装换

  • 语法

    { transform:translate(100px,100px) rotate(45deg) scale(1.2); }
  • 注意

    1. 多个转换空格隔开
    2. 顺序会影响转换的效果(先旋转会改变坐标轴方向)
    3. 有位移和其他属性的时候,记得要将位移放到最前面
需要 登录 才可以提问哦