摘要:并排顯示,要求相同高度如果要求多個塊級元素并排居中且高度相同,則要為其父元素設置屬性。成一列顯示如果只是需要讓多個塊級元素整體水平居中,并且按默認的方式縱向排列,那直接設置左右邊距為即可。
原文出處:Centering in CSS: A Complete Guide
本文只給出了不同條件下的實現方式,未對原理做探討。
PS:原來要顯示 jsfiddle 和 CodePen 之類網站的代碼預覽,只需將其以 Markdown 語法來插入鏈接即可。
對于行內元素(inline)或復合行內元素(inline-*),直接為其父元素設置文本居中即可。
.center-children { text-align: center; }
http://codepen.io/chriscoyier/pen/HulzB
該方法適用于 inline、inline-block、inline-table、inline-flex 之類的元素。
塊級元素對于塊級元素,如果給定了寬度,直接設置左右邊距為 auto 即可。
注意:對于未指定寬度的元素,默認會占滿允許的最大寬度,這時設置居中是無效的。
.center-me { margin: 0 auto; }
http://codepen.io/chriscoyier/pen/eszon
不管元素或者父元素的寬度如何,只要指定了寬度,該方法就有效。
但是,對于設置了浮動(float)的元素就不行了,這里有一個取巧的辦法可以實現浮動元素居中。
多個塊級元素對于多個塊級元素需要整體居中的情況,還可細分為以下三類:
并排顯示,高度無要求如果不要求并排的多個塊級元素有同樣的高度,那么可為這些塊級元素的父元素設置 display: inline-block 屬性,以實現所需效果。
I"m an element that is block-like with my siblings and we"re centered in a row.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.I"m an element that is block-like with my siblings and we"re centered in a row.
.inline-block-center { text-align: center; } .inline-block-center div { display: inline-block; text-align: left; }
http://codepen.io/chriscoyier/pen/ebing
并排顯示,要求相同高度如果要求多個塊級元素并排居中且高度相同,則要為其父元素設置 display: flex 屬性。
I"m an element that is block-like with my siblings and we"re centered in a row.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.I"m an element that is block-like with my siblings and we"re centered in a row.
.flex-center { display: flex; justify-content: center; }成一列顯示
如果只是需要讓多個塊級元素整體水平居中,并且按默認的方式縱向排列,那直接設置左右邊距為 auto 即可。
http://codepen.io/chriscoyier/pen/haCGt
垂直居中要實現元素的垂直居中就需要一些小技巧了。
行內元素 單行內容為行內元素/文本元素設置相等的上下內邊距即可實現單行元素的垂直居中。
.link { padding-top: 30px; padding-bottom: 30px; }
http://codepen.io/chriscoyier/pen/ldcwq
如果出于種種原因不能用上面的設置上下內邊距的方式,那么可以設置行高與元素的高度相同,這樣也能實現垂直居中的效果,但是使用這種方法要保證文本不會換行。
.center-text-trick { height: 100px; line-height: 100px; white-space: nowrap; }
http://codepen.io/chriscoyier/pen/LxHmK
多行內容對多行文本設置相等的上下內邊距也是可以實現垂直居中的,但是有時候會因為文本在表格的單元格中,或者文本所屬的元素通過 CSS 設置為表格單元格的表現方式,而無法實現垂直居中的效果。在這種情況下,可以用 vertical-align 屬性來實現垂直居中。
http://codepen.io/chriscoyier/pen/ekoFx
上面的方式不可行的話,還可以使用 flexbox,flex 只有一個子元素的話,要實現垂直居中還是很簡單的。
.flex-center-vertically { display: flex; justify-content: center; flex-direction: column; height: 400px; }
http://codepen.io/chriscoyier/pen/uHygv
對于 flexbox 方法,原文中說到父元素有指定高度之后,這種方法才有意義,但是通過測試代碼發現,父元素未指定高度也是可以垂直居中的。
Remember that it"s only really relevant if the parent container has a fixed height (px, %, etc), which is why the container here has a height.
除此之外,還可以使用 ghost element,這種方法是將一個完整高度的偽類放在容器中,讓文本與這個偽類縱向居中對齊。
.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; }
http://codepen.io/chriscoyier/pen/ofwgD
塊級元素 元素高度已知在網頁布局中,元素高度不確定的情況很普遍:比如元素寬度改變,文本重排之后元素高度就會改變。文本的樣式不同,元素高度也會不同。文本的字數不同,元素高度也會不同。具有固定高寬比的元素,比如圖片,當尺寸改變時,其高度也會變化,等等情況。
但是如果元素高度已知,可以用下面的方法來實現垂直居中:
.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; */ }
http://codepen.io/chriscoyier/pen/HiydJ
元素高度未知該方法就是先將元素相對于其原始位置向下移動父元素高度的一半距離,再將該元素相對其本身的高度向上移動一半,這樣就能實現垂直居中的效果了。
.parent { position: relative; } .child { position: absolute; top: 50%; transform: translateY(-50%); }
http://codepen.io/chriscoyier/pen/lpema
簡單粗暴的 flexbox用 flexbox 的話,實現起來就簡單多了。
.parent { display: flex; flex-direction: column; justify-content: center; }
http://codepen.io/chriscoyier/pen/FqDyi
水平和垂直均居中簡單地把上面提到的實現水平居中和垂直居中的方法結合起來自然是可以的,但是這個需求也可以分為以下三類來實現:
元素寬度及高度已知將元素相對于其父元素的寬度/高度值向右并向下移動一半的距離,這時元素左上角的頂點剛好位于父元素的中心。然后再通過設置負邊距值的方法,將元素相對于其自身的寬度/高度值向左并向上移動一半的距離,就可實現水平垂直均居中的效果了。并且這種方法的瀏覽器兼容性是很好的。
.parent { position: relative; } .child { width: 300px; height: 100px; padding: 20px; position: absolute; top: 50%; left: 50%; margin: -70px 0 0 -170px; }
http://codepen.io/chriscoyier/pen/JGofm
元素的寬度或高度未知如果元素的寬度或者高度未知,則在將元素相對于父元素的寬高往向右并向下移動一半距離后,再用 transform 屬性來將其向左并向上移動自身寬度及高度值一般的距離即可。
.parent { position: relative; } .child { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
http://codepen.io/chriscoyier/pen/lgFiq
flexbox 大法要通過 flexbox 來實現水平垂直均居中,就要使用兩個居中屬性來實現:
.parent { display: flex; justify-content: center; align-items: center; }
http://codepen.io/chriscoyier/pen/msItD
PS: 剛發現還可以通過下面的方式實現子元素水平及垂直均居中:
.parent { display: flex; justify-content: center; } .child { // 不加這一條的話,子元素的高度將撐滿父元素。加了這一條,才能讓子元素以正常的高度顯示,并且在垂直方向上居中。 margin: auto 0; }總結
信 CSS,得永生。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/115278.html
摘要:春節閑來無事,看看自己在上寫的文章,想不到已經篇了,各方面的都有,那就分類整理一下吧,也方便自己和別人查看。 春節閑來無事,看看自己在SegmentFault上寫的文章,想不到已經20篇了,各方面的都有,那就分類整理一下吧,也方便自己和別人查看。 CSS CSS Background-Size 屬性小記 [譯]關于垂直居中 Vertical Align 的探討 [譯]CSS 居中(...
摘要:絕對底部前端掘金來自國外的設計達人,純,可以實現當正文內容很少時,底部位于窗口最下面。有效解決圖片使用單位邊角缺失的問題前端掘金起因在移動端使用布局時圖片也需要用單位。 CSS 絕對底部 - 前端 - 掘金來自國外的設計達人,純CSS,可以實現: 當正文內容很少時,底部位于窗口最下面。當改變窗口高度時,不會出現重疊問題。甚至,創造該CSS的人還專門成立一個網站介紹這個CSS底部布局方案...
閱讀 2203·2021-11-18 10:02
閱讀 3302·2021-11-11 16:55
閱讀 2706·2021-09-14 18:02
閱讀 2445·2021-09-04 16:41
閱讀 2077·2021-09-04 16:40
閱讀 1204·2019-08-30 15:56
閱讀 2223·2019-08-30 15:54
閱讀 3175·2019-08-30 14:15