- 本文總結CSS居中,包括水平居中和垂直居中.本文至關於CSS決策樹,下次再遇到CSS居中問題時有章可循.
- 參考Centering in CSS: A Complete Guide和【基礎】這15種CSS居中的方式,你都用過哪幾種
- 本文的引用歸原做者全部.
- 代碼在線演示工具JSbin使用指南
inline
或inline-*
元素水平居中給須要居中的元素一個block
父元素,須要居中子元素爲 文本 或者 inline
, inline-block
, inline-table
, inline-flex
css
核心代碼html
.center-children { text-align: center; }
JSbin演示地址
效果:
segmentfault
block
元素水平居中父元素爲block
,子元素也爲bolck
,且子元素設置了寬度(沒寬度子元素就繼承父元素寬度,居中沒有意義).
不管正在居中塊級元素的寬度或父級的寬度如何,都會起做用。瀏覽器
方法:子元素margin: 0 auto;
左右外邊距設置爲自動填充ide
核心代碼工具
.center-me { margin: 0 auto; }
效果:
佈局
block
元素水平居中block
元素一行排列水平居中inline-block
,原理是將子元素轉化爲inline-block
.再用text-align: center;
display: flex
.注意:子元素高度會保持一致.看下方例子.核心代碼:ui
.inline-block-center { text-align: center; } .inline-block-center div { display: inline-block; text-align: left; } .flex-center { display: flex; justify-content: center; }
效果:spa
block
元素每行一個水平居中由於每一個block
元素獨佔一行,因此方法仍然是margin: 0 auto;
演示:
垂直居中比較麻煩
inline
或 inline-*
元素單行垂直居中須要垂直居中的元素爲單行的inline
或 inline-*
元素,例如一個text或者a連接(包括a連接變化而成的按鈕)
padding
(推薦)上下和左右使用相同的padding
能夠不用設置寬高,既能夠在修改文本內容是自適應,又能夠減小出現BUG的概率.
核心代碼:
.link { padding-top: 30px; padding-bottom: 30px; }
演示:
line-height
與高度相同核心代碼
.center-text-trick { height: 100px; line-height: 100px; white-space: nowrap; /*nowrap文本內的換行無效內容只能在一行顯示*/ }
多行文本使用增長上下padding
垂直居中的方法仍然有效且良好,不需設置寬高,推薦使用.
若是這樣作不起做用,那麼文本所在的元素多是table或者table-cell元素,不管是真正的table仍是後期本身添加的CSS.
下面說說這兩種狀況使用其餘方法的垂直居中.
display: table;
和vertical-align: middle;
核心代碼:
.center-table { display: table; } .center-table p { display: table-cell; vertical-align: middle; }
table
+vertical-align: middle
多行文本垂直居中JSbin演示
flex
佈局多行文本居中一個flex-child能夠簡單地在flex-parent的中心.
核心代碼
.flex-center-vertically { display: flex; justify-content: center; flex-direction: column; height: 400px; }
block
元素垂直居中block
元素高度原理是絕對定位,top: 50%;
而後 margin-top
設置爲負邊距且值爲他自己高度的一半.
核心代碼:
.parent { position: relative; } .child { position: absolute; top: 50%; height: 100px; margin-top: -50px; /* account for padding and border if not using box-sizing: border-box; */ }
注意:使用
position: absolute;
絕對定位會使元素脫離文檔流
block
元素高度未知垂直居中藉助CSS3中的transform
屬性向Y軸反向偏移50%的方法實現垂直居中。可是部分瀏覽器存在兼容性的問題。
核心代碼:
.parent { position: relative; } .child { position: absolute; top: 50%; transform: translateY(-50%); }
block
元素高度未知垂直居中核心代碼:
.parent { display: flex; flex-direction: column; justify-content: center; }
核心代碼:
依舊是絕對定位+寬高一半的負邊距
.parent { position: relative; } .child { width: 300px; height: 100px; padding: 20px; position: absolute; top: 50%; left: 50%; margin: -70px 0 0 -170px; }
利用2D變換,在水平和垂直兩個方向都向反向平移寬高的一半,從而使元素水平垂直居中。
核心代碼
.parent { position: relative; } .child { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
flex
佈局垂直水平居中核心代碼:
.parent { display: flex; justify-content: center; align-items: center; }
grid
佈局垂直水平居中核心代碼:
body, html { height: 100%; display: grid; } span { /* thing to center */ margin: auto; }