zoukankan      html  css  js  c++  java
  • css水平垂直居中

    1.CSS的水平居中,

      1.1 父元素是块状元素,子元素为行内元素的居中,直接设置text-aglin: center ,常见的文本,span 标签,button,img等行内元素都是可以使其水平居中的

        

    .box{
                text-align: center;
            }
    
    <div class="box">
            <span>11111</span>
            <button>123</button>
        </div>

      1.2 父元素为块状元素,子元素也为块状元素

        1.2.1 子元素宽度已知,则可以设置子元素 margin 0 auto,就可以使子元素相对于父元素水平居中

    <style>
            .box{
                background-color: pink;
            }
            .con-box{
                width: 300px;
                margin: 0 auto;
                height: 30px;
                background-color: aqua;
            }
        </style>
    
    <div class="box">
            <div class="con-box">
    
            </div>
        </div>

      1.3  父元素为块状元素,子元素为块状元素宽度不定,直接设置子元素display:inline,  然后设置 父元素的text-aglin:center

    <style>
            .box{
                background-color: pink;
                text-align: center
            }
            .con-box{
                display: inline;
            }
        </style>
    <div class="box">
            <div class="con-box">
                111111
            </div>
        </div>

        注: 使用弹性布局,使用定位,都是可以使子元素相对于父元素水平居中的

    2.垂直居中

      2.1 父元素为块状元素,子元素为行内元素,如单行文本,直接设置父元素的line-height 等于父元素的高度,

    <style>
            .box{
                background-color: pink;
                height: 50px;
                line-height: 50px;
            }
            .con span{
                line-height: 50px;
            }
        </style>
    
    <div class="box">
            <span> 111111</span>
        </div>

      2.2 父元素为块状元素,子元素为多行文本,则设置父元素的line-height 等于父元素高度除于行数,

    .box{
                background-color: pink;
                height: 50px;
                line-height: 25px;
            }
            .con span{
                line-height: 50px;
            }
    
    <div class="box">
            <span> 111111</span><br>
            <span> 111111</span><br>
        </div>

      2.3 父元素为块状元素,子元素也为块状元素,

        2.3.1 子元素高度未知,改变父元素的display 属性 设置为 table-cell,然后设置vertical-align:middle;

    <style>
            .box{
                background-color: pink;
                height: 50px;
                display: table-cell;
                vertical-align:middle;
            }
            .box .con-box{
                background-color: aqua;
            }
        </style>
    
    <div class="box">
            <div class="con-box"> 
                1111
            </div>
        </div>

        2.3.2 子元素高度已知,则设置margin-top,元素高度减去子元素高度除于2; 记住一定要设置父元素的overflow: hidden; 

          (相邻块状元素 margin会共享,取最大值,不设置overflow: hidden,子元素的margin-top:10px 会跑到父元素上)

    <style>
            .box{
                background-color: pink;
                height: 50px;
                overflow: hidden;           
         }
            .box .con-box{
                margin-top: 10px;
                height: 30px;
                line-height: 30px;
                background-color: aqua;
            }
        </style>
    
    <div class="box">
            <div class="con-box"> 
                1111
            </div>
        </div>

        2.3.3 子元素为图片,直接可以设置父元素display: table-cell; vertical-align: middle;

    <style>
            .box{
                background-color: pink;
                height: 450px;
                display: table-cell; 
                vertical-align: middle;         
         }
    </style>

      2.3.4 子元素为多个,比如图片,外加别的行内元素,使用2.3.3,文本可以不用改变,必读给图片加 vertical-align: middle;

        <style>
            .box{
                background-color: pink;
                height: 450px;
                display: table-cell; 
                vertical-align: middle;         
         }
         img{
             vertical-align: middle
         }
        </style>
    
    <div class="box">
            <img src="../xunguang-4.jpg" alt="">
            <span>12123123</span>
            1111111
        </div>

    3.CSS 水平垂直居中 上面两两组和使可以实现的,我们主要看一下定位和flex 实现水平垂直居中

      3.1子元素高度未知,高度已知的块状元素水平垂直居中,(宽度未知,块状元素肯定使占满整行的,就不存在水平居中了)

        3.1.1使用定位配置,配合margin 0 auto ,top 50%,宽度未知,只能使用transform:translateY(-50%);

      <style>
            .box{
                background-color: pink;
                height: 450px;  
                position: relative; // relative 默认沾满整行,absolute话,未设置宽度则由子元素撑开    
                overflow: hidden; 
            }
            .box .con-box{
                position: relative;
                width: 300px;
                margin: 0 auto;
                background-color: aqua;
                top:50%;
                transform: translateY(-50%);
            }
    
        </style>
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
        </div>

        3.1.2,使用定位,子元素 left 0 right 0 top 0 bottom 0 margin auto (一定要注意父子元素的定位属性)

    <style>
            .box{
                background-color: pink;
                height: 450px;  
                position: relative; /* 父元素一定为relative */   
                overflow: hidden; 
            }
            .box .con-box{
                position: absolute; /*  *子元素一定 为absolete*/
                width: 300px;
                background-color: aqua;
                top:0;
                left: 0;
                right: 0;
                bottom: 0;
                margin: auto;
            }
        </style>
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
        </div>

      3.2 ,子元素宽度,高度都已知,3.1 上的两种方法都适用宽度高度已经的子元素水平垂直居中

        3.2.1 margin-top: -width/2 具体的值, transform: translateY(-50%) 这个有兼容性问题,需要ie9以上,具体宽度值则无兼容性问题,

    <style>
                    .box{
                background-color: pink;
                height: 450px;  
                position: relative; 
                overflow: hidden; 
            }
            .box .con-box{
                position: relative;
                width: 300px;
                height: 400px;
                margin: 0 auto;
                background-color: aqua;
                top:50%;
                margin-top: -200px
            }
    
    
        </style>
    
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
        </div>

        上面方法的变化版

    <style>
                    .box{
                background-color: pink;
                height: 450px;  
                position: relative; 
                overflow: hidden; 
            }
            .box .con-box{
                position: relative;
                width: 300px;
                height: 400px;
                background-color: aqua;
                top:50%;
                left: 50%;
                margin-top: -200px;
                margin-left: -150px;
            }
    
    
        </style>
    
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
        </div>

    4 flex 水平垂直居中

      flex 主轴上居中,交叉轴上居中,flex 有很大的兼容性问题,一般用于移动端,很简单

    <style>
                    .box{
                background-color: pink;
                height: 450px;  
                display: flex;
                justify-content: center;
                align-items: center
            }
            .box .con-box{
                width: 300px;
                height: 400px;
                background-color: aqua;
            }
    
    
        </style>
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
        </div>

         多个子元素也一样实现

        子元素可以单独设置对其方式

    <style>
                    .box{
                background-color: pink;
                height: 450px;  
                display: flex;
                justify-content: center;
                align-items: center
            }
            .box .con-box{
                width: 200px;
                height: 400px;
                background-color: aqua;
            }
            .box .con-box2{
                width: 200px;
                height: 400px;
                background-color: lightcyan;
            }
            .box .con-box3{
                width: 200px;
                height: 400px;
                background-color: gold;
                align-self: flex-end;
            }
    
        </style>
    <div class="box">
            <div class="con-box">
                123123123123
                <br>
                1222222222
            </div>
            <div class="con-box2">
                123123123123
                <br>
                1222222222
            </div>
            <div class="con-box3">
                123123123123
                <br>
                1222222222
            </div>
        </div>

       总结 

       1.水平居中,能使用margin: 0 auto ,这最简单的,不能的话就把子元素转化成inline,然后使用text-aglin:center,无兼容性问题。

        上面达不到需求,可以考虑使用定位,移动端能使用flex 就使用flex

         2. 垂直居中,单行文本,使用line-height 等于父元素高度,如果不行,就可以设置父元素display:table-cell,vertical-align: middle;

        能解决一大部分问题,如果还不行就考虑定位配合margin-top:-width/2,使用margin。移动端能使用flex 就使用flex.

      如果您还有更好的方法,欢迎给我留言,共同学习,共同进步。up

  • 相关阅读:
    Linux-文件目录管理
    20. 有效的括号
    242. 有效的字母异位词
    387. 字符串中的第一个唯一字符
    136. 只出现一次的数字
    14. 最长公共前缀
    268. 丢失的数字
    169. 多数元素
    26. 删除有序数组中的重复项
    283. 移动零
  • 原文地址:https://www.cnblogs.com/czkolve/p/10686182.html
Copyright © 2011-2022 走看看