水平居中
內聯或類內聯元素(譬如文字或連結)
在塊級父元素中讓內聯元素居中。
data:image/s3,"s3://crabby-images/1f973/1f973564e37f1c1060381ffb2b391051b2068b60" alt="圖片.png"
data:image/s3,"s3://crabby-images/eec9e/eec9ec3c2f0d0456523612a0c578d3d0d52a2ef2" alt="圖片.png"
塊級元素
data:image/s3,"s3://crabby-images/bd3bc/bd3bc664658a63e1ecfbcd1bee65cc593b6b11bf" alt="圖片.png"
data:image/s3,"s3://crabby-images/e937c/e937c2bb1c65a7afd37b42905205f0f57788aa5b" alt="圖片.png"
多個塊級元素
如果要讓多個塊級元素在同一水平線上居中,那麼可以修改它們的 display
值。這裡有兩個示例,其中一個使用了 inline-block
的顯示方式,另一個使用了 flexbox
的顯示方式。
HTML:
<main class="inline-block-center">
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row. I have more content in me than my siblings do.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
</main>
<main class="flex-center">
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row. I have more content in me than my siblings do.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
</main>
複製程式碼
CSS:
body {
background: #f06d06;
font-size: 80%;
}
main {
background: white;
margin: 20px 0;
padding: 10px;
}
main div {
background: black;
color: white;
padding: 15px;
max-width: 125px;
margin: 5px;
}
.inline-block-center {
text-align: center;
}
.inline-block-center div {
display: inline-block;
text-align: left;
}
.flex-center {
display: flex;
justify-content: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/8b2cb/8b2cbb2ba4a4661c903d9010b5cecf208a7ad73f" alt="圖片.png"
如果你想讓多個垂直堆疊的塊元素,那麼仍然可以通過設定 margin-left
和 margin-right
為 auto
來實現。
HTML:
<main>
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row. I have more content in me than my siblings do.
</div>
<div>
I'm an element that is block-like with my siblings and we're centered in a row.
</div>
</main>
複製程式碼
CSS:
body {
background: #f06d06;
font-size: 80%;
}
main {
background: white;
margin: 20px 0;
padding: 10px;
}
main div {
background: black;
margin: 0 auto;
color: white;
padding: 15px;
margin: 5px auto;
}
main div:nth-child(1) {
width: 200px;
}
main div:nth-child(2) {
width: 400px;
}
main div:nth-child(3) {
width: 125px;
}
複製程式碼
data:image/s3,"s3://crabby-images/d9332/d9332b9975e20e146ea8e60ca4e6b6b5ffdf727d" alt="圖片.png"
垂直居中
內聯或類內聯元素(譬如文字或連結)
單行
data:image/s3,"s3://crabby-images/259fa/259fa1a5234869d41146511b4bb179f482f7327e" alt="圖片.png"
padding-top
和 padding-bottom
就可以實現垂直居中。
data:image/s3,"s3://crabby-images/539e5/539e54dde9a70589173eb04085b60ec2e27e2a09" alt="圖片.png"
如果不能使用 padding
屬性來實現垂直居中,而且已知文字不會換行,那麼就可以讓 line-height
和 height
相等,從而實現垂直居中。
data:image/s3,"s3://crabby-images/9da44/9da44f83723847447a9c64e03a4e808a395b468b" alt="圖片.png"
多行
對於多行文字,同樣可以使用等值 padding-top
和 padding-bottom
的方式實現垂直居中。如果你在使用過程中發現這種方法沒見效,那麼你可以通過 CSS 為文字設定一個類似 table-cell
的父級容器,然後使用 vertical-align
屬性實現垂直居中。
HTML:
<table>
<tr>
<td>
I'm vertically centered multiple lines of text in a real table cell.
</td>
</tr>
</table>
<div class="center-table">
<p>I'm vertically centered multiple lines of text in a CSS-created table layout.</p>
</div>
複製程式碼
CSS:
body {
background: #f06d06;
font-size: 80%;
}
table {
background: white;
width: 240px;
border-collapse: separate;
margin: 20px;
height: 250px;
}
table td {
background: black;
color: white;
padding: 20px;
border: 10px solid white;
/* default is vertical-align: middle; */
}
.center-table {
display: table;
height: 250px;
background: white;
width: 240px;
margin: 20px;
}
.center-table p {
display: table-cell;
margin: 0;
background: black;
color: white;
padding: 20px;
border: 10px solid white;
vertical-align: middle;
}
複製程式碼
data:image/s3,"s3://crabby-images/f033f/f033faf829f096d0d2704b708c0aad45b94bfd37" alt="圖片.png"
還可以使用 flexbox
實現垂直居中,對於父級容器為 display: flex
的元素來說,它的每一個子元素都是垂直居中的。
data:image/s3,"s3://crabby-images/87fa3/87fa3af1b950d226cd4eebcc8a833200a672b8ef" alt="圖片.png"
data:image/s3,"s3://crabby-images/fa58c/fa58c8e313ca4aed9faaefc35c9a58cceefa1d73" alt="圖片.png"
上述方法只適用於父級容器擁有確定高度的元素。
如果上述方法都不起作用,那麼你就需要使用被稱為幽靈元素(ghost element)的解決方式:在垂直居中的元素上新增偽元素,設定偽元素的高等於父級容器的高,然後為文字新增vertical-align: middle;
樣式,即可實現垂直居中。
data:image/s3,"s3://crabby-images/d5680/d5680f206c1766e9a007826f0b36a8ac6c98b3ea" alt="圖片.png"
<div class="ghost-center">
<p>I'm vertically centered multiple lines of text in a container. Centered with a ghost pseudo element</p>
</div>
複製程式碼
CSS:
body {
background: #f06d06;
font-size: 80%;
}
div {
background: white;
width: 240px;
height: 200px;
margin: 20px;
color: white;
resize: vertical;
overflow: auto;
padding: 20px;
}
.ghost-center {
position: relative;
}
.ghost-center::before {
content: " ";
display: inline-block;
height: 100%;
width: 1%;
vertical-align: middle;
}
.ghost-center p {
display: inline-block;
vertical-align: middle;
width: 190px;
margin: 0;
padding: 20px;
background: black;
}
複製程式碼
data:image/s3,"s3://crabby-images/4003a/4003a454fddd0edf8fd7cf8497260d03da0b00c1" alt="圖片.png"
塊級元素
已知元素高度
.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; */
}
複製程式碼
data:image/s3,"s3://crabby-images/45029/45029dac8eb27535c6907d86e95a25bde375c2b4" alt="圖片.png"
data:image/s3,"s3://crabby-images/c74f2/c74f2e094b563b3945f4e434174640854dbcb43b" alt="圖片.png"
元素高度未知
如果我們不知道元素的高度,那麼就需要先將元素定位到容器的中心位置,然後使用 transform
的 translate
屬性,將元素的中心和父容器的中心重合,從而實現垂直居中。
data:image/s3,"s3://crabby-images/bc37e/bc37ec49bb9e6314f4f6a2a39808b3104ffcff78" alt="圖片.png"
data:image/s3,"s3://crabby-images/88777/88777bd1d038622f3b450f703a8c2411cb6dd848" alt="圖片.png"
data:image/s3,"s3://crabby-images/654e4/654e45e19f0806df7b4f3f29ae35582ce0c9a02c" alt="圖片.png"
使用flexbox
data:image/s3,"s3://crabby-images/eca12/eca125eb9aa57379925a2d2944ccec0f60f43676" alt="圖片.png"
data:image/s3,"s3://crabby-images/da214/da214ea8d8ed677a8aee3a8dcf02017db2706a23" alt="圖片.png"
data:image/s3,"s3://crabby-images/9940d/9940da99f82f462572fb55b29b87a4debeb84680" alt="圖片.png"
水平垂直居中
寬高固定
設定父級容器為相對定位的容器,設定子元素絕對定位的位置 position: absolute; top: 50%; left: 50%
,最後使用負向 margin
實現水平和垂直居中,margin
的值為寬高(具體的寬高需要根據實際情況計算 padding
)的一半。
data:image/s3,"s3://crabby-images/184a9/184a9e311c56d4b8bcbd0f9f65b99c04ffa69773" alt="圖片.png"
data:image/s3,"s3://crabby-images/90051/90051053783374f6c511bdf0d214030cc8dc6182" alt="圖片.png"
data:image/s3,"s3://crabby-images/61a4d/61a4d52e39a34e496750a9b6f5eea02d893d9c5a" alt="圖片.png"
寬高未知
data:image/s3,"s3://crabby-images/165db/165dbdd4e011bd4a657ba75d11efdf99761f7350" alt="圖片.png"
position: absolute; top: 50%; left: 50%
。不同的是,接下來需要使用 transform: translate(-50%, -50%);
實現垂直居中。
data:image/s3,"s3://crabby-images/7e309/7e3098ce2f64efcc14499df0e72bf28bf0568698" alt="圖片.png"
data:image/s3,"s3://crabby-images/ceff2/ceff26c7896340d1e1a45d7c0bf4b381637895dd" alt="圖片.png"
transform
有一個缺陷,就是當計算結果含有小數時(比如 0.5
),會讓整個元素看起來是模糊的,一種解決方案就是為父級元素設定 transform-style: preserve-3d;
樣式。
data:image/s3,"s3://crabby-images/9bc2e/9bc2eafc2deb0b652063f2a717a2bb8531fb58cd" alt="圖片.png"
使用flexbox
使用 flexbox 實現水平和垂直居中,只需使用兩條居中屬性。
data:image/s3,"s3://crabby-images/1819d/1819dceaa78996624cd5efe44657b2d1d82e0b7f" alt="圖片.png"
data:image/s3,"s3://crabby-images/18dab/18dabe1372924e4c78da135e9c81f2dd00a4ea25" alt="圖片.png"
data:image/s3,"s3://crabby-images/2e78e/2e78ef1b58a74433ad19d1e6a32dedd8f2356359" alt="圖片.png"
使用grid
當只有一個元素的時候,這是個小技巧。
data:image/s3,"s3://crabby-images/9a665/9a665c71f500ba7811224c11355d6fecf7950e61" alt="圖片.png"
data:image/s3,"s3://crabby-images/c7d05/c7d05c6ff2d4b1e756f4301ffba9a427125e943c" alt="圖片.png"
data:image/s3,"s3://crabby-images/ade5c/ade5cf00f7baf6c041674e11e82f2c29cc95cf80" alt="圖片.png"
感謝閱讀本文。 本文整理自: Centering in CSS: A Complete Guide CSS居中完整指南