六種居中的方法
阿新 • • 發佈:2018-11-02
方案一:
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 |
|
方案六:
對子盒子實現絕對定位,利用calc計算位置
<p class="outerBox calc"> </p><p class="innerBox">calc</p> <p></p> /*絕對定位,clac計算位置*/ .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); }