css Transfrom属性顺序问题: rotate() scale() 顺序不同导致效果不同

今天解 bug 时发现 transform 属性值的顺序会导致不同的效果。

例如:

.div1 {
  transform: scale(0.5, 1) rotate(45deg);
}
.div2 {
  transform: rotate(45deg) scale(0.5, 1)
}

上面的两个属性仅仅是调换了位置,却程现了不同的显示效果。

写了一个 codeopen 的 demo

在这里插入图片描述

查阅后才发现,scale() 是对水平轴和垂直轴进行缩放,而 rotate() 会改变轴的方向。因此如果先旋转再进行缩放,如果 scale(x, y) 中的 x 和 y 的值不一致,则会导致一个变形的效果,也就是下面红色方块的样子。使用 translate(x,y) 同理。

因此,以后使用 transform 属性值时需要格外注意这个顺序,rotate() 尽量放在最后。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值