如何将一个div水平垂直居中?6种方法做推荐

方案一:

div绝对定位水平垂直居中【margin:auto实现绝对定位元素的居中】,

兼容性:,IE7及之前版本不支持

如何将一个div水平垂直居中?6种方法做推荐
    div{
            width: 200px;
            height: 200px;
            background: green;
            position:absolute;
            left:0;
            top: 0;
            bottom: 0;
            right: 0;
            margin: auto;
        }
如何将一个div水平垂直居中?6种方法做推荐

 

方案二:

div绝对定位水平垂直居中【margin 负间距】     这或许是当前最流行的使用方法。

如何将一个div水平垂直居中?6种方法做推荐
         div{
            width:200px;
            height: 200px;
            background:green;
            position: absolute;
            left:50%;
            top:50%;
            margin-left:-100px;
            margin-top:-100px;
        }        
如何将一个div水平垂直居中?6种方法做推荐

 

方案三:

div绝对定位水平垂直居中【Transforms 变形】

兼容性:IE8不支持;

如何将一个div水平垂直居中?6种方法做推荐
        div{
            width: 200px;
            height: 200px;
            background: green;
            position:absolute;
            left:50%;    /* 定位父级的50% */
            top:50%;
            transform: translate(-50%,-50%); /*自己的50% */
        }            
如何将一个div水平垂直居中?6种方法做推荐

 

方案四:

css不定宽高水平垂直居中

如何将一个div水平垂直居中?6种方法做推荐
     .box{

             height:600px;
             display:flex;
             justify-content:center;
             align-items:center;
               /* aa只要三句话就可以实现不定宽高水平垂直居中。 */
        }
        .box>div{
            background: green;
            width: 200px;
            height: 200px;
        }
如何将一个div水平垂直居中?6种方法做推荐

 

 

 

方案五:

将父盒子设置为table-cell元素,可以使用text-align:center和vertical-align:middle实现水平、垂直居中。比较完美的解决方案是利用三层结构模拟父子结构

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 <p class="outerBox tableCell">   </p><p class="ok">     </p><p class="innerBox">tableCell</p>   <p></p> <p></p>     /* table-cell实现居中 将父盒子设置为table-cell元素,设置 text-align:center,vertical-align: middle; 子盒子设置为inline-block元素 */ .tableCell{   display: table; } .tableCell .ok{   display: table-cell;   text-align: center;   vertical-align: middle; } .tableCell .innerBox{   display: inline-block; }

  

 

方案六:

对子盒子实现绝对定位,利用calc计算位置

如何将一个div水平垂直居中?6种方法做推荐
<p class="outerBox calc">
    </p><p class="innerBox">calc</p>
<p></p>


/*绝对定位,clac计算位置*/
.calc{
  position: relative;
}
.calc .innerBox{
  position: absolute;
  left:calc(50% - 宽度/2);
  top:calc(50% - 高度/2);
}
如何将一个div水平垂直居中?6种方法做推荐

 

上一篇:习题10-3 递归实现指数函数 (15分)


下一篇:问题 C: 采用递归求第n位数(c#)