flex布局:實(shí)例

先來看看幾種常見的布局方式

我的主要參考資料是Landon Schropp的文章和Solved by Flexbox怨愤。

一、骰子的布局

骰子的一面调限,最多可以放置9個點(diǎn)涂召。

下面坠非,就來看看Flex如何實(shí)現(xiàn),從1個點(diǎn)到9個點(diǎn)的布局果正。你可以到codepen查看Demo炎码。

如果不加說明盟迟,本節(jié)的HTML模板一律如下。

上面代碼中潦闲,div元素(代表骰子的一個面)是Flex容器攒菠,span元素(代表一個點(diǎn))是Flex項(xiàng)目。如果有多個項(xiàng)目歉闰,就要添加多個span元素辖众,以此類推。

1.1 單項(xiàng)目

首先和敬,只有左上角1個點(diǎn)的情況凹炸。Flex布局默認(rèn)就是首行左對齊,所以一行代碼就夠了昼弟。

.box {display:flex;}

設(shè)置項(xiàng)目的對齊方式啤它,就能實(shí)現(xiàn)居中對齊和右對齊。

.box {display:flex;justify-content:center;}

.box {display:flex;justify-content:flex-end;}

設(shè)置交叉軸對齊方式舱痘,可以垂直移動主軸变骡。

.box {display:flex;align-items:center;}

.box {display:flex;justify-content:center;align-items:center;}

.box {display:flex;justify-content:center;align-items:flex-end;}

.box {display:flex;justify-content:flex-end;align-items:flex-end;}

1.2 雙項(xiàng)目

.box {display:flex;justify-content:space-between;}

.box {display:flex;flex-direction:column;justify-content:space-between;}

.box {display:flex;flex-direction:column;justify-content:space-between;align-items:center;}

.box {display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;}

.box {display:flex;}.item:nth-child(2) {align-self:center;}

.box {display:flex;justify-content:space-between;}.item:nth-child(2) {align-self:flex-end;}

1.3 三項(xiàng)目

.box {display:flex;}.item:nth-child(2) {align-self:center;}.item:nth-child(3) {align-self:flex-end;}

1.4 四項(xiàng)目

.box {display:flex;flex-wrap:wrap;justify-content:flex-end;align-content:space-between;}

HTML代碼如下。

CSS代碼如下衰粹。

.box {display:flex;flex-wrap:wrap;align-content:space-between;}.column {flex-basis:100%;display:flex;justify-content:space-between;}

1.5 六項(xiàng)目

.box {display:flex;flex-wrap:wrap;align-content:space-between;}

.box {display:flex;flex-direction:column;flex-wrap:wrap;align-content:space-between;}

HTML代碼如下锣光。


CSS代碼如下。

.box {display:flex;flex-wrap:wrap;}

.row{flex-basis:100%;display:flex;}

.row:nth-child(2){justify-content:center;}

.row:nth-child(3){justify-content:space-between;}

1.6 九項(xiàng)目

.box {display:flex;flex-wrap:wrap;}

二铝耻、網(wǎng)格布局

2.1 基本網(wǎng)格布局

最簡單的網(wǎng)格布局,就是平均分布蹬刷。在容器里面平均分配空間瓢捉,跟上面的骰子布局很像,但是需要設(shè)置項(xiàng)目的自動縮放办成。

HTML代碼如下泡态。


CSS代碼如下。

.Grid {display:flex;}

.Grid-cell {flex:1;}

2.2 百分比布局

某個網(wǎng)格的寬度為固定的百分比迂卢,其余網(wǎng)格平均分配剩余的空間某弦。

HTML代碼如下。


.Grid {display:flex;}

.Grid-cell {flex:1;}

.Grid-cell.u-full {flex:0 0 100%;}

.Grid-cell.u-1of2 {flex:0 0 50%;}

.Grid-cell.u-1of3 {flex:0 0 33.3333%;}

.Grid-cell.u-1of4 {flex:0 0 25%;}

三而克、圣杯布局

圣杯布局(Holy Grail Layout)指的是一種最常見的網(wǎng)站布局靶壮。頁面從上到下,分成三個部分:頭部(header)员萍,軀干(body)腾降,尾部(footer)。其中軀干又水平分成三欄碎绎,從左到右為:導(dǎo)航螃壤、主欄抗果、副欄。

HTML代碼如下奸晴。


CSS代碼如下冤馏。

.HolyGrail {display:flex;min-height:100vh;flex-direction:column;}

header,footer {flex:1;}

.HolyGrail-body {display:flex;flex:1;}

.HolyGrail-content {flex:1;}

.HolyGrail-nav, .HolyGrail-ads {

/* 兩個邊欄的寬度設(shè)為12em */

flex:0 0 12em;

}

.HolyGrail-nav {

/* 導(dǎo)航放到最左邊 */

order:-1;

}

如果是小屏幕,軀干的三欄自動變?yōu)榇怪悲B加寄啼。

@media (max-width:768px){

????.HolyGrail-body {flex-direction:column;flex:1;}

.HolyGrail-nav,.HolyGrail-ads,.HolyGrail-content {flex:auto;}

}

四逮光、輸入框的布局

我們常常需要在輸入框的前方添加提示,后方添加按鈕辕录。

HTML代碼如下睦霎。


CSS代碼如下。

.InputAddOn {display:flex;}

.InputAddOn-field {flex:1;}

五走诞、懸掛式布局

有時副女,主欄的左側(cè)或右側(cè),需要添加一個圖片欄蚣旱。

HTML代碼如下碑幅。

CSS代碼如下。

.Media {display:flex;align-items:flex-start;}

.Media-figure {margin-right:1em;}

.Media-body {flex:1;}

六塞绿、固定的底欄

有時沟涨,頁面內(nèi)容太少,無法占滿一屏的高度异吻,底欄就會抬高到頁面的中間裹赴。這時可以采用Flex布局,讓底欄總是出現(xiàn)在頁面的底部诀浪。

HTML代碼如下棋返。

CSS代碼如下。

.Site {display:flex;min-height:100vh;flex-direction:column;}

.Site-content {flex:1;}

七雷猪,流式布局

每行的項(xiàng)目數(shù)固定睛竣,會自動分行。

CSS的寫法求摇。

.parent {

????width:200px;

????height:150px;

????background-color:black;

????display:flex;

????flex-flow:row wrap;

????align-content:flex-start;

}

.child {

????box-sizing:border-box;

????background-color:white;

????flex:0 0 25%;

????height:50px;

????border:1px solid red;

}

文章轉(zhuǎn)自阮一峰博客http://www.ruanyifeng.com/blog/2015/07/flex-examples.html射沟,感謝分享

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市与境,隨后出現(xiàn)的幾起案子验夯,更是在濱河造成了極大的恐慌,老刑警劉巖嚷辅,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件簿姨,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)扁位,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門准潭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人域仇,你說我怎么就攤上這事刑然。” “怎么了暇务?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵泼掠,是天一觀的道長。 經(jīng)常有香客問我垦细,道長择镇,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任括改,我火速辦了婚禮腻豌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嘱能。我一直安慰自己吝梅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布惹骂。 她就那樣靜靜地躺著苏携,像睡著了一般。 火紅的嫁衣襯著肌膚如雪对粪。 梳的紋絲不亂的頭發(fā)上右冻,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天,我揣著相機(jī)與錄音著拭,去河邊找鬼国旷。 笑死,一個胖子當(dāng)著我的面吹牛茫死,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播履羞,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼峦萎,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了忆首?” 一聲冷哼從身側(cè)響起爱榔,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎糙及,沒想到半個月后详幽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年唇聘,在試婚紗的時候發(fā)現(xiàn)自己被綠了版姑。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡迟郎,死狀恐怖剥险,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情宪肖,我是刑警寧澤表制,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站控乾,受9級特大地震影響么介,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蜕衡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一壤短、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧衷咽,春花似錦鸽扁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鼎姊,卻和暖如春骡和,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背相寇。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工慰于, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人唤衫。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓婆赠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親佳励。 傳聞我的和親對象是個殘疾皇子休里,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評論 2 345

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