有兴趣理解更多关于前台开发和网页设计的知识吗?请阅读关于CSS转换属性的优秀教程。
假如没有CSS转换,转换属性只可以将其应使用到的对象翻转。所以,在现实生活中,这两种选择是一起应使用的。
这个属性拥有的权力:
rotate(angle),
skew(angle),
translate(x,y),
scale(x,y),
matrix(n,n,n,n,n,n).
除了maybematrix之外,所有的值都是很清楚的。
旋转和倾斜选项用角度度数(值能是负数,能输入超过360度)。例如,输入1080deg进行三个完整的旋转。
scale选项只用数字,并且根据给定的宽度和高度的参数定义该对象的添加/减少程度。
所有这些属性接受矩阵(仍可可以不是self-explained)和X和Y有特殊选项增加到语法,在这种情况下,只要要一个参数和属性,在旋转和倾斜的情况下,变得相对于X或者Y轴(例如translateX(),写入scaleY()等)。
矩阵选项能做所有事情(你期望的更少吗?)确切的语法是矩阵(scaleX()、skewY()、skewX()、scaleY()、translateX()、translateY())。即便里面没有旋转选项,它也能旋转。我不可以说更多(由于这是数学……请查看此邮件以获取更多信息。
还能通过在一个转换中定义多个转换组合。
div {
transform: rotate(90deg) scale(2) translateY(-50%) translateX(50%);
}
这一特性最近被使用于的最流行的效果是,主要是旋转导航、社交和其余信息,并使它们垂直。在下面的两个例子中,我们用了transform: rotate(-90deg)属性。
2D属性值rotate,translate,scale和matrix具备加入它们与z轴平行的3D值。额外的3D属性是perspective,它定义了3D变换元素的透视图。Perspective用一个值来定义元素距视图的距离。
我相信在了解2D选项之后,所有这些都是不言自明的。
该transform属性使用于定义元素的两个状态之间的转换。与transition他们一样,他们成为一对强大的夫妻,正如开头提到的那样。
.box {
...
background-color: #0000FF;
-webkit-transition:background-color 2s, -webkit-transform 2s;
transition:background-color 2s, transform 2s;
}
.box:hover {
background-color: #FFCCCC;
-webkit-transform: rotate(180deg);
transform: rotate(180deg);
}
这种组合是transform和transition属性最常见的使用法 。记住在第一个状态transform 中将转换定义为值并在第二个状态中定义转换非常重要。