1. div絕對定位水平垂直居中【margin:auto實現絕對定位元素的居中】
兼容性:,IE7及之前版本不支持
div{ width: 200px; height: 200px; background: green; position:absolute;
????????????left:0;top: 0; bottom: 0;right: 0; margin: auto;}
2. div絕對定位水平垂直居中【margin 負間距】
div{ width:200px; height: 200px; background:green;position: absolute;
? ? ? ? ? ? left:50%; top:50%;
? ? ? ? ? ? margin-left:-100px;margin-top:-100px;}
3. div絕對定位水平垂直居中【Transforms 變形】
兼容性:IE8不支持;
div{ width: 200px; height: 200px;?
?background: green;
position:absolute;
left:50%;/* 定位父級的50% */top:50%;
transform: translate(-50%,-50%);/*自己的50% */ }
4. css不定寬高水平垂直居中
.box{ height:600px;
????????????display:flex;
? ? ? ? ? ? justify-content:center;
? ? ? ? ? ? align-items:center;? ? ? ? ? ? ? /* aa只要三句話就可以實現不定寬高水平垂直居中促王。 */? ? ? ? }? ? ? ??
.box>div{?
?? ? ? ? ? background: green;
? ? ? ? ? ? width: 200px;
? ? ? ? ? ? height: 200px;
? ? ? ? }
5. 將父盒子設置為table-cell元素而晒,可以使用text-align:center和vertical-align:middle實現水平、垂直居中迅耘。比較完美的解決方案是利用三層結構模擬父子結構
/*
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;
}
6. 對子盒子實現絕對定位,利用calc計算位置
.calc{ position: relative;}
.calc .innerBox{ position: absolute;?
?left:-webkit-calc((500px - 200px)/2);?
?top:-webkit-calc((120px - 50px)/2);?
?left:-moz-calc((500px - 200px)/2);?
?top:-moz-calc((120px - 50px)/2);
?left:calc((500px - 200px)/2);
?top:calc((120px - 50px)/2);
}