css3动画&2D|3D

一、css3的transform属性

  • 2d坐标轴(图示)

  • x轴:水平,向右为正,向左为负

  • y轴:垂直,向下为正,向上为负

2d转换的方法

1、2D变形:平移、旋转、缩放、倾斜

1) transform: translate()平移

  • transform: translate(x,y) 沿着x轴和y轴移动

  • transform: translateX(x) 沿着x轴移动

  • transform: translateY(y) 沿着y轴移动

取值:

  • px

  • 百分比(强调相对于元素本身计算)

  • 水平,向右为正,向左为负

  • 垂直,向下为正,向上为负

  • x与y之间用逗号隔开

水平向右为正值,垂直方向向下正值

/* 沿着水平方向位移 */
当为一个值的时候,只沿着水平方向位移
transform: translate(50px);
   注意:元素位移之后,原来的位置还在

3)transform: scale() 缩放

  • transform: scale(x,y) 沿着x轴和y轴缩放

  • transform: scaleX(x) 沿着x轴缩放

  • transform: scaleY(y) 沿着y轴缩放

取值范围0~1之间表示缩小,1表示正常大小,1以上表示放大,默认值为1 取值为负值表示先翻转后缩放

为一个值的时候,沿着水平方向和垂直方向等比例缩放

元素缩放为0 后,原来的位置还在

x与y之间用逗号隔开

transform: scale(1.5);/* 沿着水平方向和垂直方向都放大1.5倍,等比例缩放 */
transform: scale(-1.5);/* 先翻转,然后 沿着水平方向和垂直方向都放大1.5倍 */

4)transform: skew() 倾斜

  • transform: skew(x,y) 沿着x轴和y轴倾斜

  • transform: skewX(x) 沿着x轴倾斜

  • transform: skewY(y) 沿着y轴倾斜

单位deg(角度) 正值,向左上角和右下角倾斜;负值,向右上角和左下角倾斜

为一个值的时候,只沿着水平方向倾斜

  /* 为一个值的时候,只沿着水平方向位移 */
        .box1:hover {
            transform: skew(45deg);
        }
 /* skew(30deg,45deg) 围绕 X 轴把元素翻转 30 度,围绕 Y 轴翻转 45 度 */
        .box2:hover {
            background-color: tomato;
            transform: skew(30deg, 45deg);
        }
​
        .box3:hover {
            transform: skewX(-45deg);
        }
​
        .box4:hover {
            transform: skewY(45deg);
​
        }
        .box5:hover {
            transform: skewY(-45deg);
        }

5)旋转,位移,缩放,倾斜的复合写法

属性之间用空格隔开,先位移再旋转
​
    .wrap:hover .box1 {
            transform: rotate(135deg);
            transform: translate(50px);
            transform: scale(1.5);
            /* 复合 先位移再旋转*/
            transform: translate(100px) rotate(120deg) scale(1.5);
        }
  • 总结:

名称语法取值单位其他
位移transform:translate();一个值(沿着水平方向位移),两个值像素pxtransform: translateX(); transform: translateY()
旋转transform: rotate();一个值deg角度
缩放transform: scale();一个值(等比例缩放)、两个值没有单位transform: scaleX(); transform: scaleY()
倾斜transform: skew();一个值(沿着水平方向倾斜)、两个值deg角度transform: skewX(); transform: skewY();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值