CSS垂直水平居中總結(jié)

css實(shí)現(xiàn)垂直水平居中的方法多種溃斋,各種方法各有優(yōu)劣撇吞,查閱網(wǎng)上資料,自己總結(jié)于此老客,方便日后應(yīng)用拭荤。

1. 絕對(duì)定位居中

.box {
        position: absolute;
        top: 0; right: 0; bottom: 0; left: 0;
        overflow: auto;
        width: 50%;
        height: 50%;
        margin: auto;
    }

優(yōu)點(diǎn):

  • 支持跨瀏覽器茵臭,包括IE8-IE10.
  • 無(wú)需其他特殊標(biāo)記,CSS代碼量少
  • 支持百分比%屬性值和min-/max-屬性
  • 只用這一個(gè)類可實(shí)現(xiàn)任何內(nèi)容塊居中
  • 不論是否設(shè)置padding都可居中(在不使用box-sizing屬性的前提下)
  • 內(nèi)容塊可以被重繪
  • 完美支持圖片居中

缺點(diǎn):

  • 必須聲明高度
  • 建議設(shè)置overflow:auto來(lái)防止內(nèi)容越界溢出
  • 在Windows Phone設(shè)備上不起作用

2.負(fù)外邊距居中
塊元素尺寸已知舅世,外邊距margin取負(fù)數(shù)旦委,大小為width/height(不使用box-sizing: border-box時(shí)包括padding)的一半,再加上top: 50%; left: 50%;

.box{
        position: absolute;
        top: 50%; left: 50%;
        width: 200px;
        height: 200px;
        padding: 60px;
        margin-left: -130px;
        margin-top: -130px;
    }

優(yōu)點(diǎn):

  • 兼容IE6雏亚,7

缺點(diǎn):

  • 不能自適應(yīng)缨硝。不支持百分比尺寸和min-/max-屬性設(shè)置。
  • 內(nèi)容可能溢出容器罢低。
  • 邊距大小與padding,和是否定義box-sizing: border-box有關(guān)查辩,計(jì)算需要根- 據(jù)不同情況。

3. Transforms居中

.box{
        position: absolute;
        top: 50%; left: 50%;
        width: 50%;
        margin: 0 auto;
        -webkit-transform: translate(-50%,-50%);
            -ms-transform: translate(-50%,-50%);
                transform: translate(-50%,-50%);
    }

優(yōu)點(diǎn):

  • 內(nèi)容可變高度

缺點(diǎn):

  • IE8不支持

  • 屬性需要寫瀏覽器廠商前綴

  • 可能干擾其他transform效果

  • 某些情形下會(huì)出現(xiàn)文本或元素邊界渲染模糊的現(xiàn)象

4. Table-Cell居中

HTML
<div class="container">
    <div class="box">
        <div class="centent">

        </div>
    </div>
</div>

CSS
.container {
        display: table;
        width: 500px;
        height: 500px;
    }

    .box {
        display: table-cell;
        vertical-align: middle;
    }

    .centent {
        width: 50%;
        margin: 0 auto;
    }

優(yōu)點(diǎn):

  • 高度可變
  • 內(nèi)容溢出會(huì)將父元素?fù)伍_(kāi)
  • 跨瀏覽器兼容性好

缺點(diǎn):

  • 需要額外html標(biāo)記

5. Flex居中

.container {
        display: flex;
        flex-direction: column; /* 改變排列方向 */
        justify-content: center;
        align-items: center;
    }

優(yōu)點(diǎn):

  • 內(nèi)容塊的寬高任意奕短,優(yōu)雅的溢出
  • 可用于更復(fù)雜高級(jí)的布局技術(shù)中

缺點(diǎn):

  • IE8/IE9不支持宜肉。
  • Body需要特定的容器和CSS樣式。
  • 運(yùn)行于現(xiàn)代瀏覽器上的代碼需要瀏覽器廠商前綴翎碑。
  • 表現(xiàn)上可能會(huì)有一些問(wèn)題
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末谬返,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子日杈,更是在濱河造成了極大的恐慌遣铝,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,743評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件莉擒,死亡現(xiàn)場(chǎng)離奇詭異酿炸,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)涨冀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門填硕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人鹿鳖,你說(shuō)我怎么就攤上這事扁眯。” “怎么了翅帜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,285評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵姻檀,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我涝滴,道長(zhǎng)绣版,這世上最難降的妖魔是什么胶台? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,485評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮杂抽,結(jié)果婚禮上诈唬,老公的妹妹穿的比我還像新娘。我一直安慰自己默怨,他們只是感情好讯榕,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,581評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著匙睹,像睡著了一般愚屁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上痕檬,一...
    開(kāi)封第一講書(shū)人閱讀 49,821評(píng)論 1 290
  • 那天霎槐,我揣著相機(jī)與錄音,去河邊找鬼梦谜。 笑死丘跌,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的唁桩。 我是一名探鬼主播闭树,決...
    沈念sama閱讀 38,960評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼荒澡!你這毒婦竟也來(lái)了报辱?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,719評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤单山,失蹤者是張志新(化名)和其女友劉穎碍现,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體米奸,經(jīng)...
    沈念sama閱讀 44,186評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡昼接,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,516評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了悴晰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片慢睡。...
    茶點(diǎn)故事閱讀 38,650評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖铡溪,靈堂內(nèi)的尸體忽然破棺而出一睁,到底是詐尸還是另有隱情,我是刑警寧澤佃却,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站窘俺,受9級(jí)特大地震影響饲帅,放射性物質(zhì)發(fā)生泄漏复凳。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,936評(píng)論 3 313
  • 文/蒙蒙 一灶泵、第九天 我趴在偏房一處隱蔽的房頂上張望育八。 院中可真熱鬧,春花似錦赦邻、人聲如沸髓棋。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,757評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)按声。三九已至,卻和暖如春恬吕,著一層夾襖步出監(jiān)牢的瞬間签则,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,991評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工铐料, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留渐裂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,370評(píng)論 2 360
  • 正文 我出身青樓钠惩,卻偏偏與公主長(zhǎng)得像柒凉,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子篓跛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,527評(píng)論 2 349

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

  • 問(wèn)答題47 /72 常見(jiàn)瀏覽器兼容性問(wèn)題與解決方案膝捞? 參考答案 (1)瀏覽器兼容問(wèn)題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,737評(píng)論 1 92
  • 1.絕對(duì)定位居中技術(shù) 我們一直用margin:auto實(shí)現(xiàn)水平居中,而一直認(rèn)為margin:auto不能實(shí)現(xiàn)垂直居...
    DecadeHeart閱讀 1,601評(píng)論 0 3
  • H5移動(dòng)端知識(shí)點(diǎn)總結(jié) 閱讀目錄 移動(dòng)開(kāi)發(fā)基本知識(shí)點(diǎn) calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇閱讀 4,435評(píng)論 0 26
  • 移動(dòng)開(kāi)發(fā)基本知識(shí)點(diǎn) 一.使用rem作為單位 html { font-size: 100px; } @media(m...
    橫沖直撞666閱讀 3,460評(píng)論 0 6
  • 選擇qi:是表達(dá)式 標(biāo)簽選擇器 類選擇器 屬性選擇器 繼承屬性: color举塔,font绑警,text-align,li...
    wzhiq896閱讀 1,732評(píng)論 0 2