transform(变形)
CSS3中可以通过transform属性修改元素的变形、旋转、缩放、倾斜特性,在CSS3中transform主要包括以下几种:旋转rotate、倾斜skew、缩放scale和移动translate以及矩阵变形matrix
transform : none | <transform-function> [ <transform-function> ]*
transform中使用多个变形函数时需要有空格隔开
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都有作用
坐标轴
data:image/s3,"s3://crabby-images/c75a0/c75a0187be17a1e5d8989cbc5bd6380da464c4df" alt=""
data:image/s3,"s3://crabby-images/2863f/2863f19c66dc88692809d04c68e92b1ab550a6e7" alt=""
data:image/s3,"s3://crabby-images/12ce9/12ce9b27a152ce6bf83c012d356c0ebf9b90a2b1" alt=""
matrix(矩阵)
工具
transform多值的顺序问题
当transforrm属性同时拥有多个变换函数时,顺序的不同,得到的结果可能也会不同
<div class="item item1"></div>
<div class="item item2"></div>
.item{
width: 100px;
height: 100px;
border: 1px solid #111;
position: absolute;
top: 300px;
left: 300px;
}
.item2{
transform: translate(130px) rotate(45deg);
}
先x轴移动130px, 然后旋转45度
data:image/s3,"s3://crabby-images/26065/2606570bc3c38d7fe308ad4c5544261532fd2271" alt=""
.item2{
transform: rotate(45deg) translate(130px);
}
先旋转45度, 然后x轴移动130px
data:image/s3,"s3://crabby-images/2ad98/2ad98910e7321aec1f41a2855a5cc57cf10d36fb" alt=""
我们会发现如果是先旋转, 然后x轴移动130px, 它不只是在x轴移动了, 在y轴也移动了, 这里个人的理解是旋转之后, 我们的参考坐标发生了变化,向这样
data:image/s3,"s3://crabby-images/6a73a/6a73a3f0996ac584766f3400ac28a02a5dda59b8" alt=""
当旋转45度后,元素的整个坐标系都旋转了45度
表盘
<p data-height="266" data-theme-id="0" data-slug-hash="GZXLZL" data-default-tab="result" data-user="lulupy" data-embed-version="2" class="codepen">See the Pen <a href="http://codepen.io/lulupy/pen/GZXLZL/">GZXLZL</a> by lulu (<a href="http://codepen.io/lulupy">@lulupy</a>) on <a href="http://codepen.io">CodePen</a>.</p>
<script async src="//assets.codepen.io/assets/embed/ei.js"></script>
网友评论