如何將一個div水平垂直居中?6種方法做推薦


方案一:

div絕對定位水平垂直居中【margin:auto實現絕對定位元素的居中】,

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

復制代碼
    div{
            width: 200px;
            height: 200px;
            background: green;
            position:absolute;
            left:0;
            top: 0;
            bottom: 0;
            right: 0;
            margin: auto;
        }
復制代碼

 

方案二:

div絕對定位水平垂直居中【margin 負間距】     這或許是當前最流行的使用方法。

復制代碼
         div{
            width:200px;
            height: 200px;
            background:green;
            position: absolute;
            left:50%;
            top:50%;
            margin-left:-100px;
            margin-top:-100px;
        }        
復制代碼

 

方案三:

div絕對定位水平垂直居中【Transforms 變形】

兼容性:IE8不支持;

復制代碼
        div{
            width: 200px;
            height: 200px;
            background: green;
            position:absolute;
            left:50%;    /* 定位父級的50% */
            top:50%;
            transform: translate(-50%,-50%); /*自己的50% */
        }            
復制代碼

 

方案四:

css不定寬高水平垂直居中

復制代碼
     .box{

             height:600px;
             display:flex;
             justify-content:center;
             align-items:center;
               /* aa只要三句話就可以實現不定寬高水平垂直居中。 */
        }
        .box>div{
            background: green;
            width: 200px;
            height: 200px;
        }
復制代碼

 

 

 

方案五:

將父盒子設置為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計算位置

復制代碼
<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);
}
復制代碼

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM