Flexbox

flex box

display: flex | inline-flex

定義了一個flex容器; 內(nèi)聯(lián)或塊取決于給定的值。它為所有直接的子元素提供了一個彈性環(huán)境。

.container{
    dispaly: flex | inline-flex;
}

flex-direction: row | row-reverse | column | column-reverse

建立了主軸,從而定義了flex項目放置在flex容器中的方向。Flexbox是單向布局概念。將flex項目視為主要布置在水平行或垂直列中。

  • row 瀏覽器中默認, 主軸方向 從左到右 默認不換行
  • row-reverse 反轉(zhuǎn) row 排列
  • column 側(cè)軸方向 從上到下
  • column-reverse 反轉(zhuǎn) column 排列
.container{
    flex-direction: row | row-reverse | column | column-reverse 
}

flex-wrap: nowrap | wrap | wrap-reverse

默認情況下,flex項目將全部嘗試適合一行(默認情況下不換行)。你可以改變它,并允許項目根據(jù)需要用這個屬性進行換行。

  • nowrap 默認 不換行(子元素可能會溢出)
  • wrap flex項目將從上到下成多行(flex 子元素溢出的部分會被放置到下一行)
  • wrap-reverse 反轉(zhuǎn) wrap 排列
.container{
    flex-wrap: nowrap | wrap | wrap-reverse
}

flex-flow: <‘flex-direction’> || <‘flex-wrap’>

這是一個簡寫flex-directionflex-wrap屬性,它們一起定義了flex容器的主軸和側(cè)軸。默認是row nowrap

.container{
    flex-flow: <‘flex-direction’> || <‘flex-wrap’>
}

justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly

定義了沿主軸的對齊。當一條線上的所有flex項目都不靈活或靈活,但達到其最大尺寸時,它有助于分配剩余空間。當物品溢出時,它也對物品的排列起到一定的控制作用。

  • flex-start 項目從flex盒子的起始位置排列
  • flex-end 項目從flex盒子的結(jié)束位置排列
  • center 項目沿著flex盒子向行中間對齊(沿主軸居中對齊)
  • space-between 項目均勻分布在行中; 第一項是在起始行,最后一行是最后一行
  • space-around 物品均勻分布在線上,周圍有相同的空間。請注意,視覺上空間不相等,因為所有物品在兩側(cè)都有相同的空間。第一個項目將在容器邊緣有一個空間單位,但下一個項目之間有兩個空間單元,因為下一個項目有其自己的間距
  • space-evenly 項目是分布式的,以便任何兩個項目之間的間距(以及到邊緣的空間)相等
.container{
    justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly
}

align-items: flex-start | flex-end | center | baseline | stretch

定義了flex項目沿當前行的側(cè)軸放置的默認行為。可以將其視為justify-content側(cè)軸(垂直于主軸)的版本。

  • flex-start 項目側(cè)軸上邊沿對齊
  • flex-end 項目側(cè)軸下邊沿對齊
  • center 項目側(cè)軸居中
  • baseline 項目基線對齊
  • stretch 默認 拉伸填充容器
.container{
    align-items: flex-start | flex-end | center | baseline | stretch
}

align-content: flex-start | flex-end | center | space-between | space-around | stretch

當側(cè)軸上有額外的空間時,這會將flex容器的按justify-content對齊,類似于如何在主軸內(nèi)對齊各個項目。
注意:只有一行是彈性項目時,此屬性不起作用

  • flex-start 各行向flex容器的起始位置對齊
  • flex-end 各行向flex容器的結(jié)束位置對齊
  • center 各行向flex容器的中間對齊
  • space-between 各行在flex容器中平均分布。如果剩余的空間是負數(shù)或flex容器中只有一行,該值等效于'flex-start'。在其它情況下,第一行的側(cè)軸起始邊界緊靠住flex容器的側(cè)軸起始內(nèi)容邊界,最后一行的側(cè)軸結(jié)束邊界緊靠住flex容器的側(cè)軸結(jié)束內(nèi)容邊界,剩余的行則按一定方式在flex窗口中排列,以保持兩兩之間的空間相等
  • space-around 各行在flex容器中平均分布,兩端保留子元素與子元素之間間距大小的一半。如果剩余的空間是負數(shù)或flex容器中只有一行,該值等效于'center'。在其它情況下,各行會按一定方式在flex容器中排列,以保持兩兩之間的空間相等,同時第一行前面及最后一行后面的空間是其他空間的一半。
  • stretch 拉伸填充容器
.container{
    align-content: flex-start | flex-end | center | space-between | space-around | stretch
}

order: <integer>

默認情況下,flex項目按源代碼順序排列。但是,該order屬性控制它們在flex容器中的顯示順序。
order屬性用于更改在主軸方向上排列順序。
order數(shù)值越小,排列越靠前,默認為0,可以為負數(shù)。

.item {
  order: <integer>; /* default is 0 */
}

flex-grow:<number>

定義了Flex項目在必要時增長的能力。它接受作為比例的無單位價值。它規(guī)定了該項目應該占用的flex容器內(nèi)的可用空間量。
如果所有項目都flex-grow設置為1,則容器中剩余的空間將平均分配給所有子元素。如果其中一個元素的值為2,則剩余空間將占用其他空間的兩倍。
注意:負數(shù)無效, 為0時不伸縮

.item{
    flex-grow: <number> /*default 0 */
}

flex-shrink: <number>

定義了flex項目在必要時收縮的能力。
注意:負數(shù)無效

.item{
    flex-shrink: <number>; /* default 1 */
}
.container_8{
    display: flex;
    width: 300px;
}
.container_8 .flex_item{
    width: 100px;
    height: 100px;
}
.container_8 .flex_item:nth-child(1){
    flex-shrink: 0;
}
.container_8 .flex_item:nth-child(2){
    flex-shrink: 2;
}
.container_8 .flex_item:nth-child(3){
    flex-shrink: 2;
}
.container_8 .flex_item:nth-child(4){
    flex-shrink: 2;
}

上例中 shrink的總數(shù)值為 6 , .container_8 .flex_item:nth-child(1)的shrink值為0, 則其寬度為 100px。而其他三個元素的寬度為(300 - 100) / 6 * 2 = 66.67px

flex-basis: <length> | auto

這將在分配剩余空間之前定義元素的默認大小。它可以是一個長度(例如20%,5rem等)或關(guān)鍵字。該auto關(guān)鍵字的意思是“看看我的寬度或高度屬性”(暫時由main-size關(guān)鍵字完成,直到棄用)。該content關(guān)鍵字的意思是“它根據(jù)項目的內(nèi)容大小”,此關(guān)鍵字不能很好地支持,所以很難進行測試,并更難知道它的兄弟max-contentmin-contentfit-content
如果設置為0,則不會考慮內(nèi)容的額外空間。如果設置為auto,多余空間將根據(jù)其flex-grow值分配。

.item{
    flex-basis: <length> | auto; /* default auto */
}

flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]

這是速記flex-grow, flex-shrinkflex-basis組合。第二個和第三個參數(shù)(flex-shrinkflex-basis)是可選的。默認是 0 1 auto

.item{
    flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

align-self: auto | flex-start | flex-end | center | baseline | stretch

允許align-items為各個flex項目覆蓋默認對齊方式(或由其指定的對齊方式).
請注意floatclear并且vertical-align對flex項目沒有影響。

.item {
  align-self: auto | flex-start | flex-end | center | baseline | stretch;
}
.container_11{
    display: flex;
    align-items: flex-start;
    height: 150px;
}
.container_11 .flex_item{
    width: 100px;
    height: 100px;
}
.container_11 .flex_item:nth-child(1){
    align-self: center
}
.container_11 .flex_item:nth-child(2){
    align-self: flex-end;
}

by @shine(xiaoshaoqq@gmail.com)

date: 2018-03-06

github地址

example

參考:Flexbox完整指南

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,967評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,273評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,870評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,742評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,527評論 6 407
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,010評論 1 322
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,108評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,250評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,769評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,656評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,853評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,371評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,103評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,472評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,717評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,487評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,815評論 2 372

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

  • H5移動端知識點總結(jié) 閱讀目錄 移動開發(fā)基本知識點 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇閱讀 4,583評論 0 26
  • 前言 FlexBox是css3的一種新的布局方式,天生為解決布局問題而存在的它,比起傳統(tǒng)的布局方式,我們使用Fle...
    zevei閱讀 1,428評論 23 3
  • 簡書的Markdown貌似不支持插入iframe,所以文章里的JSFiddle示例都改做截圖了,如果有需要可以點擊...
    kangflict閱讀 1,130評論 2 8
  • title: flex布局date: 2017-07-07 14:13:33tags: css筆記 flexbox...
    Gary23閱讀 1,542評論 0 0
  • FlexBox 布局基本用法 1、什么是FlexBox Flexbox是Flexible Box的縮寫,意為'彈性...
    光強_上海閱讀 13,311評論 3 27