早安,各位,又是炎热的一天,深圳的天气真是变化无常,静下心来分享下css3里的2D变形方法。
转换是CSS3中具有颠覆性的特征之一,可以实现元素的位移、旋转、倾斜、缩放,甚至支持矩阵方式,配合过渡和即将学习的动画知识,可以取代大量之前只能靠Flash才可以实现的效果。
移动 translate(x, y)
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> div { width: 100px; height: 100px; background-color: #ccc; /*transform: translate(x, y);x y 可以是负值*/ /*变形: 移动*/ transition: all 0.5s;/*当点击鼠标时,慢慢的移动,松开鼠标之后,慢慢的回去*/ } div:active { /* a:active鼠标点击没有松开的时候 触发的状态*/ transform: translate(50px, 50px);/*当点击之后,移动位置*/ /*transform: translate(50px);只移动x轴的情况这样写*/ /*transform: translate(0,50px);只移动y轴这样写*/ /*transform: translateX(50px);也可以这样写,而且一般这样写*/ /*transform: translateY(50px);也可以这样写*/ } </style> </head> <body> <div></div> </body> </html>
案例:
盒子水平垂直居中对齐的新写法
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> div { width: 200px; height: 200px; background-color: #ccc; /*transform: translate(100px);水平移动100*/ /*transform: translate(50%);这样写的话,移动的50%宽度是以他自身的宽度一半为准的,也就是div的一半,200px/2=100px,而不是以父级或浏览器的宽度的一半为准*/ /*以前我们定位的盒子居中对齐是先移动父级的一半宽度,再往回走自己宽度的一半,才能实现居中*/ /*以前的居中是这样写的*/ position: absolute; left: 50%; /* !*以父级宽度为准*!*/ top: 50%; /*margin-left: -100px;以前的居中是这样写的, 但是这样写的话就被写死了,父级宽度如果改动的话,这里也要改,他不会自动变*/ transform: translate(-50%, -50%); /*现在不需要再计算一半距离是多少,直接用50%就可以了*/ } </style> </head> <body> <div></div> </body> </html>
缩放scale(x, y)
transform:scale(0.8, 1);这里如果括号里只写一个数的话,就不像translate(x, y)一样是默认为x值了,scale()括号里如果只有一个值的话,是x y一起共同都是这个值
scale(X,Y)使元素水平方向和垂直方向同时缩放(也就是X轴和Y轴同时缩放)
scaleX(x)元素仅水平方向缩放(X轴缩放)
scaleY(y)元素仅垂直方向缩放(Y轴缩放)
scale()的取值默认的值为1,当值设置为0.01到0.99之间的任何值,作用使一个元素缩小;而任何大于或等于1.01的值,作用是让元素放大。
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> div { width: 100px; height: 100px; background-color: #ccc; margin: 100px auto; transition: all 0.5s;/* 渐变 x y 轴都变 */ } div:hover { transform: scale(1.2, 1.5); /* x 水平缩放 y垂直缩放 鼠标经过后放大,离开后复原,如果只有一个参数的话,宽度、高度都缩放,可以做一些网站的鼠标经过后图片放大的效果*/ } </style> </head> <body> <div></div> </body> </html>
旋转 rotate(deg)
可以对元素进行旋转,正值为顺时针,负值为逆时针;
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> img { margin: 100px; transition: all 0.5s; } img:hover { transform: rotate(90deg);/*这里给 -90deg的话,就是逆时针旋转*/ } </style> </head> <body> <section> <img src="https://www.jiangweishan.com/zb_users/upload/2020/05/202005131589364968696188.jpg" alt=""> </section> </body>
鼠标经过后,图片旋转90度,并且是在0.5s的时间内匀速旋转。
上面例子拓展:
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> img { margin: 100px; transition: all 0.8s;/*过渡 所有条件都过渡*/ border-radius: 50%; /*给图片圆角*/ border: 5px solid cadetblue; } img:hover { transform: rotate(360deg);/*旋转的度数写多少都可以,720都行*/ } </style> </head> <body> <section> <img src="https://www.jiangweishan.com/zb_users/upload/2020/05/202005131589364968696188.jpg" alt=""> </section> </body> </html>
拓展练习: 图片变成圆角,加边框,并且顺时针旋转360度。
transform-origin 可以调整元素转换变形的原点,上面的图片旋转是围绕中心点旋转的,也可以设置为围绕其他点旋转。
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> img { width: 200px; margin: 100px; transition: all 0.6s; transform-origin: top left;/* origin:原点。transform-origin这个属性默认值是center center 围绕中心点旋转,修改成top left之后,他就会围绕左上角旋转 如果要精确一些的话,可以写成像素的:transform-origin: 20px 30px;*/ } img:hover { transform: rotate(180deg); } </style> </head> <body> <img src="https://www.jiangweishan.com/zb_users/upload/2020/05/202005131589364968696188.jpg" alt=""> </body> </html>
倾斜 skew(deg, deg)
通过skew方法把元素水平方向上倾斜30度,处置方向保持不变。
可以使元素按一定的角度进行倾斜,可为负值,第二个参数不写默认为0。
<!doctype html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> div { font-size: 50px; font-weight: 700; margin: 100px; transition: all 0.7s; } div:hover { /*transform: skew(-30deg,0);*/ transform: skew(0, -10deg);/*y轴这个值如果大了,他会跑掉,离开鼠标能点到的地方又会跑回来*/ } </style> </head> <body> <div> 楚乔 </div> </body> </html>