CSS:跨世紀(jì)的垂直居中問題解決方案

多年來弟蚀,垂直居中問題一度成為前端開發(fā)者的熱門話題。因?yàn)檫@個(gè)需求極其常見挑豌,但又看似簡單安券,實(shí)施起來很難,尤其是涉及到尺寸不固定的情況時(shí)氓英。

html基本結(jié)構(gòu)

<main>
    <h1>我是居中的嗎侯勉?</h1>
    <p>請讓我保持居中顯示</p>
</main> 

css基本結(jié)構(gòu)

body{
    background: #DBDCFF;
    text-align: center;
}

1、基于絕對定位的方案

我們先來看兩個(gè)早期的實(shí)現(xiàn)方法铝阐,它要求元素必須有固定的寬高度:

第一種需要計(jì)算margin-topmargin-left的值

main{
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -3em;
    margin-left: -9em;
    width: 18em;
    height: 6em;
    background: #C88F6E;
}

第二種就相對簡潔了許多

main{
    position: absolute;
    top: 0; bottom: 0;
    left: 0; right: 0;
    width: 18em;
    height: 6em;
    margin: auto;
    background: #C88F6E;
}

效果如圖:

固定寬高址貌,絕對定位實(shí)現(xiàn)居中

上面的方法最大的局限就是前面說的,它要求元素必須寬高度是固定的徘键,在通常情況下练对,對那些需要居中的元素來說,其尺寸往往是由其內(nèi)容決定的吹害。那么螟凭,如果可以找到一個(gè)屬性的百分比值以元素自身的寬高作為解析基準(zhǔn),那么我們的難題也就迎刃而解了它呀!

我們或許可以從CSS變形屬性中了解一下螺男,當(dāng)我們在translate()變形函數(shù)中使用百分比值時(shí),是以該元素的自身寬度和高度為基準(zhǔn)進(jìn)行換算和移動(dòng)的纵穿。有了這個(gè)屬性下隧,我們就可以這樣解決了:

main{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #C88F6E;
}

效果如圖:

寬高度不固定,絕對定位實(shí)現(xiàn)居中

這種方法很好的滿足了我們的需求谓媒,但是也有一些需要注意的地方

  • 實(shí)際項(xiàng)目中淆院,有時(shí)不能選用絕對定位,因?yàn)樗鼘φ麄€(gè)布局影響過大

  • 如果我們需要被居中的元素高度已經(jīng)超過了視口篙耗,那它的頂部將會(huì)被截掉

  • 在某些瀏覽器中迫筑,這個(gè)方法可能會(huì)導(dǎo)致元素的顯示有一些模糊宪赶,因?yàn)樵乜赡芊胖迷诎雮€(gè)像素上。

2脯燃、基于視口單位的方案

CSS值與單位(第三版)定義了一套新的單位搂妻,稱為視口相關(guān)的長度單位。

  • vw是與視口寬度相關(guān)的辕棚。與常人理解不同的是欲主,1vw實(shí)際上表示視口寬度的1%,而不是100%逝嚎。

  • vw類似扁瓢,1vh表示視口高度的1%。

  • 當(dāng)視口寬度小于高度時(shí)补君,1vmin等于1vw引几,否則等于1vh

  • 當(dāng)視口寬度大于高度時(shí)挽铁,1vmax等于1vw伟桅,否則等于1vh

了解了以上規(guī)則叽掘,我們就可以利用它來嘗試解決垂直居中的問題:

main{
    width: 18em;
    padding: 1em 1.5em;
    margin: 50vh auto 0;
    transform: translateY(-50%);
    background: #C88F6E;
}

效果如圖:

高度不固定楣铁,利用視口實(shí)現(xiàn)居中

3、基于Flexbox的方案

很明顯這是一個(gè)目前為止的最佳方案更扁,而且現(xiàn)代瀏覽器已經(jīng)對Flexbox有相當(dāng)不錯(cuò)的支持度了盖腕。

具體代碼如下:

body{
    background: #DBDCFF;
    text-align: center;
    display: flex;
    min-height: 100vh;
    margin: 0;
}

main{
    margin: auto;
    background: #C88F6E;
}

效果如圖:

使用Flexbox實(shí)現(xiàn)居中

當(dāng)我們使用Flexbox時(shí),margin:auto不僅在水平方向上將元素居中浓镜,在垂直方向上也是如此溃列。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市膛薛,隨后出現(xiàn)的幾起案子哭廉,更是在濱河造成了極大的恐慌,老刑警劉巖相叁,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異辽幌,居然都是意外死亡增淹,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進(jìn)店門乌企,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虑润,“玉大人,你說我怎么就攤上這事加酵∪鳎” “怎么了哭当?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長冗澈。 經(jīng)常有香客問我钦勘,道長,這世上最難降的妖魔是什么亚亲? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任彻采,我火速辦了婚禮,結(jié)果婚禮上捌归,老公的妹妹穿的比我還像新娘肛响。我一直安慰自己,他們只是感情好惜索,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布特笋。 她就那樣靜靜地躺著,像睡著了一般巾兆。 火紅的嫁衣襯著肌膚如雪猎物。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天臼寄,我揣著相機(jī)與錄音霸奕,去河邊找鬼。 笑死吉拳,一個(gè)胖子當(dāng)著我的面吹牛质帅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播留攒,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼煤惩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了炼邀?” 一聲冷哼從身側(cè)響起魄揉,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拭宁,沒想到半個(gè)月后洛退,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡杰标,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年兵怯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片腔剂。...
    茶點(diǎn)故事閱讀 39,711評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡媒区,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情袜漩,我是刑警寧澤绪爸,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站宙攻,受9級特大地震影響奠货,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜粘优,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一仇味、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧雹顺,春花似錦丹墨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽王财。三九已至,卻和暖如春绒净,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背偿衰。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工挂疆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缤言,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓虏辫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鹤耍。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 44年前我們就把人類送上月球了,但現(xiàn)在我們?nèi)匀粺o法在CSS中實(shí)現(xiàn)垂直居中只盹。 在CSS中對元素進(jìn)行水平居中是非常簡單...
    康斌閱讀 15,835評論 9 28
  • 對于最流行的表格布局法和行內(nèi)塊法不去考慮孵稽,只考慮用最新的現(xiàn)代CSS去實(shí)現(xiàn) 基于絕對定位的解決方案 1.早期解決方法...
    咕咚咚bells閱讀 248評論 0 0
  • 主要摘自:《CSS 揭秘》荣刑,強(qiáng)烈推薦的一本書皿淋。 “44 年前我們就把人類送上月球了,但現(xiàn)在我們?nèi)匀粺o法在 CSS ...
    grain先森閱讀 305評論 0 3
  • 準(zhǔn)備代碼: 初始效果如圖1: 一.絕對定位解決方案 此解決方案的思路是洗鸵,距離左上角絕對定位甘凭,top和left各50...
    xuehairong閱讀 333評論 0 0
  • 44年前我們把人送上月球鸣驱,但在CSS中我們?nèi)匀徊荒芎芎脤?shí)現(xiàn)垂直居中 讓一個(gè)元素水平居中對于CSS來說非常簡單:如果...
    揮劍斬浮云閱讀 264評論 0 0