css居中的幾種方法

CSS 的居中問題是一個經(jīng)常被抱怨的東西上荡。為啥居個中要這么麻煩饱溢?我覺得可能問題不在于難,而在于每次一查萍启,有各種各樣的解決方案,你選了一個驳遵,能正常地居中了超埋,但是心里又會在想:選這個是不是最好的呢霍殴?會不會有什么問題来庭?

各種猶豫不決月弛?那就來創(chuàng)建一個決策樹吧帽衙!
水平居中

是inline元素或者inline-*元素嗎厉萝?(比如text或者links)章母?
給inline元素一個block的父元素乳怎,然后設(shè)置父元素css為text-align:center 即可搞定。
.center-children {
text-align: center;
}
是block塊元素嗎询枚?
把一個塊級元素的margin-left和margin-right設(shè)置成auto,再給定一個固定的width,即可水平居中。一般我們會寫成:margin:0 auto;
.center-me {
margin: 0 auto;
}
有多個block塊級元素的話苗傅,怎么居中渣慕?
如果你想在一行里讓多個塊級元素居中逊桦,你可以把這些塊級元素的display設(shè)置成inline-block(同時注意設(shè)置這些元素的父級元素text-align:center)强经,或者使用flexbox.
.inline-block-center {
text-align: center;
}
.inline-block-center div {
display: inline-block;
text-align: left;
}
如果使用flexbox,直接對父元素做如下設(shè)置即可:
.flex-center {
display: flex;
justify-content: center;
}
垂直居中

是inline元素或者inline-元素嗎兰迫?(比如text或者links)汁果?
單行据德?
1.設(shè)置相同的padding-top和padding-bottom.
2.如果1不能使用,可以嘗試將元素的line-height和height設(shè)置成相等的值赡译。
.link {
padding-top: 30px;
padding-bottom: 30px;
}
.center-text-trick {
height: 100px;
line-height: 100px;
white-space: nowrap;
}
多行?
設(shè)置相同的padding-top和padding-bottom.
如果1不能使用只洒,也許text所在的元素是一個table cell,可以使用 vertical-align來處理毕谴。也可以使用flexbox.
.center-table p {
display: table-cell;
margin: 0;
background: black;
color: white;
padding: 20px;
border: 10px solid white;
vertical-align: middle;
}
是block塊元素嗎?
知道元素的高度舀武。 如果你知道元素的高度瘪匿,那么像下面這樣就可以:
.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; */
}
不知道元素的高度。
.parent {
position: relative;
}
.child {
position: absolute;
top: 50%;
transform: translateY(-50%);
}
你可以使用flexbox嗎?
.parent {
display: flex;
flex-direction: column;
justify-content: center;
}
水平垂直居中

一般結(jié)合上面兩個技巧就可以做到水平和垂直居中。不過也可以分成下面這三個陣營:

元素有固定的寬度和高度(設(shè)置absolute仁锯,50%蓄愁,50%的值配合使用負的長度和寬度值可以很好地得到跨瀏覽器的支持)
.parent {
position: relative;
}
.child {
width: 300px;
height: 100px;
padding: 20px;
position: absolute;
top: 50%;
left: 50%;
margin: -70px 0 0 -170px;
}
元素沒有固定的寬度和高度(在top和left上同時使用transform屬性和負的translate百分數(shù)撮抓,注意這里的百分數(shù)是基于當(dāng)前元素的)
.parent {
position: relative;
}
.child {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
可以使用flexbox嗎妇斤?注意兩個方向上都要設(shè)置center
.parent {
display: flex;
justify-content: center;
align-items: center;
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市丹拯,隨后出現(xiàn)的幾起案子站超,更是在濱河造成了極大的恐慌,老刑警劉巖乖酬,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件死相,死亡現(xiàn)場離奇詭異,居然都是意外死亡咬像,警方通過查閱死者的電腦和手機算撮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來县昂,“玉大人肮柜,你說我怎么就攤上這事∑甙牛” “怎么了素挽?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵蔑赘,是天一觀的道長狸驳。 經(jīng)常有香客問我预明,道長,這世上最難降的妖魔是什么耙箍? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任撰糠,我火速辦了婚禮,結(jié)果婚禮上辩昆,老公的妹妹穿的比我還像新娘阅酪。我一直安慰自己,他們只是感情好汁针,可當(dāng)我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布术辐。 她就那樣靜靜地躺著,像睡著了一般施无。 火紅的嫁衣襯著肌膚如雪辉词。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天猾骡,我揣著相機與錄音瑞躺,去河邊找鬼。 笑死兴想,一個胖子當(dāng)著我的面吹牛幢哨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嫂便,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼捞镰,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了顽悼?” 一聲冷哼從身側(cè)響起曼振,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蔚龙,沒想到半個月后冰评,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡木羹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年甲雅,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坑填。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡抛人,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出脐瑰,到底是詐尸還是另有隱情妖枚,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布苍在,位于F島的核電站绝页,受9級特大地震影響荠商,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜续誉,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一莱没、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧酷鸦,春花似錦饰躲、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至摔握,卻和暖如春焦蘑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背盒发。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工例嘱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宁舰。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓拼卵,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蛮艰。 傳聞我的和親對象是個殘疾皇子腋腮,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,916評論 2 344

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

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J的外補...
    _Yfling閱讀 13,728評論 1 92
  • 一壤蚜、水平居中 1.行內(nèi)元素居中(文字/圖片)在父元素上加上text-align:center; 2.塊級元素居中設(shè)...
    我才是大田田閱讀 240評論 0 0
  • 一 外部式css樣式 (也可稱為外聯(lián)式)就是把css代碼寫一個單獨的外部文件中即寡,這個css樣式文件以“.css...
    KunMitnic閱讀 927評論 0 1
  • 前 言眾所周知著蟹,羅胖就是【羅輯思維】的創(chuàng)始人羅振宇墩蔓,那史老師為什么說:羅胖你太能說了呢?一起來看看~ 以下正文 我...
    史振鈞閱讀 2,786評論 2 2
  • 我是一匹欲騰云駕霧的孤馬 想要放縱的飛奔卻又恐墜下 我是無垠疆土上的一顆碎石 孤傲莊重的想要掙放開出花 我是奔騰的...
    舊時雨m閱讀 465評論 0 0