• CSS之容器水平垂直居中


    方法一:position加margin

    复制代码
    复制代码
    /**html**/
    <div class="wrap"> <div class="center"></div> </div> /**css**/ .wrap { 200px; height: 200px; background: yellow; position: relative; } .wrap .center { 100px; height: 100px; background: green; margin: auto; position: absolute; left: 0; right: 0; top: 0; bottom: 0; }
    复制代码
    复制代码

    兼容性:主流浏览器均支持,IE6不支持

    方法二: diaplay:table-cell

    复制代码
    复制代码
    <!-- html -->
    <div class="wrap">
         <div class="center"></div>
    </div>
    
    /*css*/
    .wrap{
         200px;
        height: 200px;
        background: yellow;
        display: table-cell;
        vertical-align: middle;
        text-align: center;
    }
    .center{
        display: inline-block;
        vertical-align: middle;
         100px;
        height: 100px;
        background: green;
    }
    复制代码
    复制代码

     兼容性:由于display:table-cell的原因,IE67不兼容

    方法三:position加 transform

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
     
    /* css */
    .wrap {
        position: relative;
        background: yellow;
         200px;
        height: 200px;}
     
    .center {
        position: absolute;
        background: green;
        top:50%;
        left:50%;
        -webkit-transform:translate(-50%,-50%);
        transform:translate(-50%,-50%);
         100px;
        height: 100px;
    }

    兼容性:ie9以下不支持 transform,手机端表现的比较好。

      

    方法四:flex;align-items: center;justify-content: center

    复制代码
    复制代码
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
    
    /* css */
    .wrap {
        background: yellow;
         200px;
        height: 200px;
        display: flex; 
        align-items: center; 
        justify-content: center;
    }
    
    .center {
        background: green;
         100px;
        height: 100px;
    }
    复制代码
    复制代码

     移动端首选

    方法五:display:flex;margin:auto

    复制代码
    复制代码
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
    
    /* css */
    .wrap {
        background: yellow;
         200px;
        height: 200px;
        display: flex; 
    }
    
    .center {
        background: green;
         100px;
        height: 100px;
        margin: auto;
    }
    复制代码
    复制代码

     移动端首选

    方法六:纯position

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
     
    /* css */
    .wrap {
        background: yellow;
        width200px;
        height200px;
        positionrelative;
    }
    /**方法一**/
    .center {
        backgroundgreen;
        positionabsolute;
        width100px;
        height100px;
        left50px;
        top50px
      
    }
    /**方法二**/
    .center {
        backgroundgreen;
        positionabsolute;
        width100px;
        height100px;
        left50%;
        top50%;
      margin-left:-50px;
      margin-top:-50px;
    }

      兼容性:适用于所有浏览器

       方法六中的方法一计算公式如下:

      子元素(conter)的left值计算公式:left=(父元素的宽 - 子元素的宽 ) / 2=(200-100) / 2=50px;

      子元素(conter)的top值计算公式:top=(父元素的高 - 子元素的高 ) / 2=(200-100) / 2=50px;

      方法二计算公式:

      left值固定为50%;

      子元素的margin-left= -(子元素的宽/2)=-100/2= -50px;

      top值也一样,固定为50%

         子元素的margin-top= -(子元素的高/2)=-100/2= -50px;

     

    方法七:兼容低版本浏览器,不固定宽高

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    <!-- html -->
    <div class="table">
        <div class="tableCell">
            <div class="content">不固定宽高,自适应</div>
        </div>
    </div>
     
    /*css*/
    .table {
        height200px;/*高度值不能少*/
        width200px;/*宽度值不能少*/
        display: table;
        positionrelative;
        float:left;
        background: yellow;
    }      
     
    .tableCell {
        displaytable-cell;
        vertical-alignmiddle;
        text-aligncenter;        
        *positionabsolute;
        padding10px;
        *top50%;
        *left50%;
    }
    .content {
        *position:relative;
        *top-50%;
        *left-50%;
         backgroundgreen;
    }

      

       

    暂时总结上面的七种,这种方法太多,其实只要习惯了其中的一两种也就够用了。

    总结

    如果是移动端,那么用方法四和方法五是比较方便的。而且支持不固定宽高的情况,快、准、狠

    也就是用 flexalign-items: center; justify-content: center; 

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
     
    /* css */
    .wrap {
        background: yellow;
        width200px;
        height200px;
        display: flex;
        align-items: center;
        justify-contentcenter;
    }
     
    .center {
        backgroundgreen;
        width100px;
        height100px;
    }

    或者  display:flex;margin:auto;

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
     
    /* css */
    .wrap {
        background: yellow;
        width200px;
        height200px;
        display: flex;
    }
     
    .center {
        backgroundgreen;
        width100px;
        height100px;
        marginauto;
    }

      

    如果是PC端,要考虑兼容性的话。方法六是不错滴,也就是纯position。

    复制代码
    复制代码
    <!-- html -->
    <div class="wrap">
        <div class="center"></div>
    </div>
    
    /* css */
    .wrap {
        background: yellow;
         200px;
        height: 200px;
        position: relative;
    }
    /**方法一**/
    .center {
        background: green;
        position: absolute;
         100px;
        height: 100px;
        left: 50px;
        top: 50px;  
      
    }
    /**方法二**/
    .center {
        background: green;
        position: absolute;
         100px;
        height: 100px;
        left: 50%;
        top: 50%; 
      margin-left:-50px; 
      margin-top:-50px;
    } 
     
    复制代码
     
     
     
     
  • 相关阅读:
    第六周作业
    第四周作业(登录验证码)
    JSP第二次作业
    JSP第一次作业求1-100间的素数
    软件测试课堂作业
    安卓作业(购物商城)
    安卓作业
    Android 简易计算器
    jsp第七次作业
    JSP第六次作业
  • 原文地址:https://www.cnblogs.com/daiyayi/p/11040227.html
Copyright © 2020-2023  润新知