• CSS3提高:CSS3 2D转换


    转换transform是CSS3中具有颠覆性的特征之一,可以实现元素的位移、旋转、缩放等效果

     转换(transform)你可以简单理解为变形

    移动:translate

    旋转:rotate

    缩放:scale

    维坐标系

    2D转换是改变标签平面上的位置和形状的一种技术,先来学习维坐标系

    2D 转换之移动 translate

    2D移动是2D转换里面的一种功能,可以改变元素在页面中的位置,类定位

    1. 语法

    1. transform: translate(x,y); 或者分开写
    2. transform: translateX(n);
    3. transform: translateY(n);

     2. 重点

    定义 2D 转换中的移动,沿着 X Y 轴移动元素

    translate最大的优点:不会影响到其他元素的位置

    translate中的百分比单位是相对于自身元素的 translate:(50%,50%);

    对行内标签没有效果

    如果里面的参数是 % 移动的距离是 盒子自身的宽度或者高度来对比的

    盒子居中

     以前是通过top: 50%;left: 50%;margin-top: -100px;margin-left: -100px;要计算高度和宽度的一半

     现在的实现方式

     这里的 50% 就是 50px 因为盒子的宽度是 100px 

    2D 转换之旋转 rotate

    2D旋转指的是让元素在2维平面内顺时针旋转或者逆时针旋转。

    1. 语法 

    transform:rotate(度数)
    

    2. 重点

    rotate里面跟度数, 单位是 deg  比如  rotate(45deg)

    角度为正时,顺时针,负时,为逆时针

    默认旋转的中心点是元素的中心点

     案例:三角形

    1. p::before {
    2. content: '';
    3. position: absolute;
    4. right: 20px;
    5. top: 10px;
    6. width: 10px;
    7. height: 10px;
    8. border-right: 1px solid #000;
    9. border-bottom: 1px solid #000;
    10. transform: rotate(45deg);
    11. }

      2D 转换中心点 transform-origin

    我们可以设置元素转换的中心点

    1. 语法

    transform-origin: x y;
    

    2. 重点

    注意后面的参数 x y 用空格隔开

    x y 默认转换的中心点是元素的中心点 (50%  50%)

    还可以给x y 设置 像素 或者  方位名词  (top  bottom  left  right  center

    案例:旋转案例

    /* 设置旋转中心点*/

    transform-origin: x y;

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
    7. <title>Document</title>
    8. <style>
    9. div{
    10. width: 200px;
    11. height: 200px;
    12. border: 1px solid pink;
    13. margin: 10px ;
    14. overflow: hidden;
    15. float: left;
    16. }
    17. div::before{
    18. content: '222';
    19. display: block;
    20. width: 100%;
    21. height: 100%;
    22. background-color: hotpink;
    23. transform: rotate(180deg);
    24. transform-origin: left bottom;
    25. transition: all 1s;
    26. }
    27. /* 鼠标经过div 里面的before复原 */
    28. div:hover::before{
    29. transform: rotate(0deg);
    30. }
    31. </style>
    32. </head>
    33. <body>
    34. <div></div>
    35. <div></div>
    36. <div></div>
    37. </body>
    38. </html>

     2D 转换之缩放scale

    缩放,顾名思义,可以放大和缩小。 只要给元素添加上了这个属性就能控制它放大还是缩小。

    1. 语法

    transform:scale(x,y);
    

    第一个是宽度,第二个是高度 

     2. 注意

    1. 注意其中的x和y用逗号分隔
    2. transform:scale(1,1) :宽和高都放大一倍,相对于没有放大
    3. transform:scale(2,2) :宽和高都放大了2
    4. transform:scale(2) :只写一个参数,第二个参数则和第一个参数一样,相当于 scale(2,2)
    5. transform:scale(0.5,0.5):缩小
    6. sacle缩放最大的优势:可以设置转换中心点缩放,默认以中心点缩放的,而且不影响其他盒子

     这个不会影响下面的盒子,而使用width和height固定高宽,会撑大盒子 

    案例:放大图片

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
    7. <title>Document</title>
    8. <style>
    9. div{
    10. overflow: hidden;
    11. float: left;
    12. margin: 10px;
    13. }
    14. div img:hover{
    15. transform: scale(1.1);
    16. }
    17. div img{
    18. transition: all .4s;
    19. }
    20. </style>
    21. </head>
    22. <body>
    23. <div>
    24. <a href="#"><img src="media/scale.jpg" alt=""></a>
    25. </div>
    26. <div>
    27. <a href="#"><img src="media/scale.jpg" alt=""></a>
    28. </div>
    29. <div>
    30. <a href="#"><img src="media/scale.jpg" alt=""></a>
    31. </div>
    32. </body>
    33. </html>

    案例:分页按钮

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
    6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    7. <title>Document</title>
    8. <style>
    9. li{
    10. width: 30px;
    11. height: 30px;
    12. border: 1px solid yellowgreen;
    13. text-align: center;
    14. line-height: 30px;
    15. list-style: none;
    16. border-radius: 50%;
    17. float: left;
    18. margin: 10px;
    19. overflow: hidden;
    20. }
    21. li:hover{
    22. transition: all .3s;
    23. transform: scale(1.1);
    24. }
    25. </style>
    26. </head>
    27. <body>
    28. <ul>
    29. <li>1</li>
    30. <li>2</li>
    31. <li>3</li>
    32. <li>4</li>
    33. <li>5</li>
    34. <li>6</li>
    35. <li>7</li>
    36. </ul>
    37. </body>
    38. </html>

    2D 转换综合写法

    注意:

    1. 同时使用多个转换,其格式为:transform: translate() rotate() scale() ...

    2. 顺序会影转换的效果。(先旋转会改变坐标轴方向

    3. 我们同时有位移和其他属性的时候,记得要将位移放到最前

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
    7. <title>Document</title>
    8. <style>
    9. div {
    10. width: 200px;
    11. height: 200px;
    12. background-color: pink;
    13. transition: all .5s;
    14. }
    15. div:hover {
    16. /* transform: rotate(180deg) translate(150px, 50px); */
    17. /* 我们同时有位移和其他属性,我们需要把位移放到最前面 */
    18. /* 先旋转 然后根据旋转后那个角度移动 */
    19. transform: translate(150px, 50px) rotate(180deg) scale(1.2);
    20. }
    21. </style>
    22. </head>
    23. <body>
    24. <div></div>
    25. </body>
    26. </html>

    2D 转换总结

    转换transform 我们简单理解就是变形 有2D 3D 之分

    我们暂且学了三个 分别是 位移 旋转 和 缩放

    2D 移动 translate(x, y)   最大的优势是不影响其他盒子, 里面参数用%,是相对于自身宽度和高度来计算的

    可以分开写比如 translateX(x)  translateY(y)

    2D 旋转 rotate(度数)    可以实现旋转元素   度数的单位是deg

    2D 缩放 sacle(x,y)   里面参数是数字 不跟单位 可以是小数   最大的优势 不影响其他盒子

    设置转换中心点 transform-origin : x y;    参数可以百分比、像素或者是方位名词

    当我们进行综合写法,同时有位移和其他属性的时候,记得要将位移放到最前

  • 相关阅读:
    git 第一次推代码
    WordPress导航主题蘑菇导航源码
    Android 逆向
    Hadoop伪分布式搭建步骤
    SAP UI5 DynamicPage 控件介绍
    C#实现最大公约数和最小公倍数
    秋招面试题系列- - -Java工程师(三)
    Oracle SQL执行计划操作(1)——表相关操作
    银行双活数据中心建设项目实践
    JESD204B时钟网络
  • 原文地址:https://blog.csdn.net/weixin_64612659/article/details/127585522