摘要:正文居中是常被開發(fā)者抱怨的問題之一。注意你不能將浮動(dòng)元素居中。水平且垂直居中你可以將前面的方法任意組合起來,實(shí)現(xiàn)完美的居中效果。這樣就可以使元素水平且垂直居中,并具有良好的瀏覽器兼容性。
參考
Centering in CSS: A Complete Guide
BY CHRIS COYIER ON SEPTEMBER 2, 2014
附:文中涉及到了flex的一些用法,如果沒有接觸過flex布局,建議看一下阮一峰老師的這篇指南:Flex 布局教程:語法篇
博客文章地址:https://guitong.github.io/blo... 顯示效果更佳。
正文:Centering in CSS: A Complete GuideCSS居中是常被開發(fā)者抱怨的問題之一。Why dose it have to be so hard?? They jeer. 我認(rèn)為問題不在于它實(shí)現(xiàn)起來有多難,而是有太多能夠?qū)崿F(xiàn)它的方法。在不同的情景下,如何去選擇,才是真正困惑我們的地方。
所以現(xiàn)在,讓我們來做一個(gè)決策樹,使CSS居中問題更容易解決。
水平居中 --> Is it inline or inline-* elements (like text or links)?它是行內(nèi)或類行內(nèi)元素嗎?(比如文本和鏈接)
你可以將行內(nèi)元素置于塊級父元素內(nèi),然后用下面的CSS代碼來使其水平居中:
.center-children { text-align: center; }
https://codepen.io/chriscoyie...
這種方法適用于inline,inline-block,inline-table,inline-flex等類型的元素。
--> Is it a block level element?它是一個(gè)塊級元素嗎?
為了居中一個(gè)塊級元素,你可以設(shè)置它的margin-left和margin-right值為auto(它的width值已給定,否則將占滿容器,也就不需要居中了)。通常簡寫如下:
.center-me { margin: 0 auto; }
https://codepen.io/chriscoyie...
無論我們將要居中的塊級元素或父元素的寬度如何,這都將起作用。
注意你不能將浮動(dòng)元素居中。There is a trick though.
--> Is there more than one block level element?有多個(gè)塊級元素嗎?
如果你需要將多個(gè)塊級元素水平居中于單行,一個(gè)好的辦法是改變它們的dispaly類型。這里有兩個(gè)例子,分別使用了inline-block和 flexbox 方法實(shí)現(xiàn):
https://codepen.io/chriscoyie...
除非你是想讓它們堆疊在一起,那么剛才使用的設(shè)置自動(dòng)外邊距值將仍然有效。
https://codepen.io/chriscoyie...
垂直居中垂直居中在CSS中比較棘手。
--> Is it inline or inline-* elements (like text or links) ?它是行內(nèi)或類行內(nèi)元素嗎?
~~> Is it a single line?是單行嗎?
有時(shí)行內(nèi)/文本元素能垂直居中顯示,僅僅是因?yàn)樗鼈冇邢嗟鹊纳舷?b>padding值。
.link { padding-top: 30px; padding-bottom: 30px; }
https://codepen.io/chriscoyie...
如果由于某些原因,設(shè)置padding的方法并不可選,而你需要居中已知不會(huì)換行的文本,有一個(gè)技巧是使其line-height值與其height值相等。
.center-text-trick { height: 100px; line-height: 100px; white-space: nowrap; }
https://codepen.io/chriscoyie...
~~> Is it multiple lines?是多行嗎?
對于多行文本的情況,依然可以使用上下padding相等的方法使其垂直居中,但是如果這種方法失效了,可能文本所在的元素是一個(gè)table cell,不管是通過字面量定義的還是通過CSS定義的。(紅葉注:這里的意思就是該元素可以是直接使用
(More on that.)
下面的例子非常清晰地展示了這種方法:
https://codepen.io/chriscoyie...
如果你不喜歡或者這種方法也不好使,也許你可以用flexbox?單個(gè)子flex元素可以非常輕松地在父flex元素內(nèi)垂直居中。
.flex-center-vertically { display: flex; justify-content: center; flex-direction: column; height: 400px; }
https://codepen.io/chriscoyie...
但是要記住,上面的討論都是基于元素父容器有一個(gè)固定的高度(px,%,etc)。
如果這些方法都無法實(shí)現(xiàn),你可以采用“ghost element”技術(shù),將一個(gè)全高度的偽元素將放置于容器中,文本將與其垂直對齊。
.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; }
https://codepen.io/chriscoyie...
—> Is it a block-level element?它是一個(gè)塊級元素嗎?
~~> Do you know the height of the element?知道元素的高度嗎?
不知道網(wǎng)頁布局的高度是相當(dāng)常見的,有很多原因:如果文本的寬度改變,那么重布局時(shí)高度就會(huì)改變;文本樣式的改變會(huì)改變高度;文本數(shù)量改變會(huì)改變高度;具有固定縱橫比的元素(如圖像),會(huì)在尺寸改變時(shí)影響高度。Etc。
但是如果你明確地知道高度,可以像這樣使其垂直居中:
.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; */ }
https://codepen.io/chriscoyie...
~~> Is the element of unknown height?未知元素高度?
沒關(guān)系。你仍然可以使用類似上面的方法使其居中。先將其絕對定位至父元素半高位置,再提升自身半高距離即可。
.parent { position: relative; } .child { position: absolute; top: 50%; transform: translateY(-50%); }
https://codepen.io/chriscoyie...
~~> Can you use flexbox?
你可以使用flexbox嗎?
如果可以,那就相當(dāng)簡單了。
.parent { display: flex; flex-direction: column; justify-content: center; }
https://codepen.io/chriscoyie...
水平且垂直居中你可以將前面的方法任意組合起來,實(shí)現(xiàn)完美的居中效果。但是我發(fā)現(xiàn)通常可以將其分為三類:
—> Is the element of fixed width and height?元素有固定的寬度和高度嗎?
先將元素絕對定位至50%/50%位置,然后加入負(fù)margin值,使該值等于高度和寬度的一半(注:元素如果有padding要記得計(jì)算進(jìn)去,參考下例)。這樣就可以使元素水平且垂直居中,并具有良好的瀏覽器兼容性。
.parent { position: relative; } .child { width: 300px; height: 100px; padding: 20px; position: absolute; top: 50%; left: 50%; margin: -70px 0 0 -170px; }
https://codepen.io/chriscoyie...
—> Is the element of unknown width and height?元素的寬度與高度未知?
如果你不知道該元素的寬高,可以將它的transform屬性設(shè)置為translate(-50%, -50%)。也可以達(dá)到相同的效果。
.parent { position: relative; } .child { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
https://codepen.io/chriscoyie...
—> Can you use flexbox?你可以使用flexbox嗎?
在水平和垂直兩個(gè)方向上居中元素,你需要用到flex的兩個(gè)屬性:
.parent { display: flex; justify-content: center; align-items: center; }
https://codepen.io/chriscoyie...
—> Can you use grid?這是一個(gè)小技巧,對單個(gè)元素來說非常有效:
body, html { height: 100%; display: grid; } span { /* thing to center */ margin: auto; }
https://codepen.io/chriscoyie...
結(jié)論You can totally center things in CSS !!!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/112682.html
摘要:但是部分瀏覽器存在兼容性的問題。核心代碼寬高不固定水平垂直居中演示使用布局垂直水平居中核心代碼使用布局垂直水平居中演示使用布局垂直水平居中核心代碼使用布局垂直水平居中演示 CSS居中完全指南——構(gòu)建CSS居中決策樹 showImg(https://segmentfault.com/img/bV8tDq); 本文總結(jié)CSS居中,包括水平居中和垂直居中.本文相當(dāng)于CSS決策樹,下次再遇到...
摘要:但是部分瀏覽器存在兼容性的問題。核心代碼寬高不固定水平垂直居中演示使用布局垂直水平居中核心代碼使用布局垂直水平居中演示使用布局垂直水平居中核心代碼使用布局垂直水平居中演示 CSS居中完全指南——構(gòu)建CSS居中決策樹 showImg(https://segmentfault.com/img/bV8tDq); 本文總結(jié)CSS居中,包括水平居中和垂直居中.本文相當(dāng)于CSS決策樹,下次再遇到...
摘要:原載于,本文著重提取文中的方法,不完全翻譯。人們經(jīng)常抱怨在中居中元素的問題,其實(shí)這個(gè)問題其實(shí)并不復(fù)雜,只是因?yàn)榉椒ū姸?,需要根?jù)情況從眾多方法中選取一個(gè)出來。 原載于CSS-Trick,本文著重提取文中的方法,不完全翻譯。如有需要,直接原文查看。 人們經(jīng)常抱怨在CSS中居中元素的問題,其實(shí)這個(gè)問題其實(shí)并不復(fù)雜,只是因?yàn)榉椒ū姸?,需要根?jù)情況從眾多方法中選取一個(gè)出來。接下來,我們做一個(gè)‘...
摘要:推薦使用使用指定打包位。開發(fā)環(huán)境跨域代理設(shè)置如果是接口,需要配置這個(gè)參數(shù)如果接口跨域,需要進(jìn)行這個(gè)參數(shù)配置通過新窗口打開項(xiàng)目內(nèi)頁面 ————僅以此文記錄個(gè)人使用vuejs開發(fā)項(xiàng)目對一些需求的處理方法,不定期更新... 加載favicon.ico圖標(biāo) //index.html // build/webpack.dev.conf.js new HtmlWebpackPlugin({ ...
摘要:在文本前面插入一個(gè)高度為百分百的偽元素,讓文本與其垂直對齊。塊級元素或者使用垂直水平居中或者使用 翻譯自 https://css-tricks.com/centering-css-complete-guide/ 預(yù)先給出這樣的樣式 .container { width: 100%; height: 200px; background-color: azur...
閱讀 1453·2023-04-25 19:00
閱讀 4156·2021-11-17 17:00
閱讀 1768·2021-11-11 16:55
閱讀 1526·2021-10-14 09:43
閱讀 3130·2021-09-30 09:58
閱讀 858·2021-09-02 15:11
閱讀 2128·2019-08-30 12:56
閱讀 1406·2019-08-30 11:12