flex彈性盒子布局

一味悄、Flex布局是什么侍瑟?

Flex是Flexible Box的縮寫涨颜,翻譯成中文就是“彈性盒子”茧球,用來為盒裝模型提供最大的靈活性抢埋。任何一個容器都可以指定為Flex布局羹令。

.box{

? ? display: -webkit-flex; /*在webkit內(nèi)核的瀏覽器上使用要加前綴*/

? ? display: flex; //將對象作為彈性伸縮盒顯示

}

當(dāng)然福侈,行內(nèi)元素也可以使用Flex布局肪凛。

.box {

? ? display: inline-flex; //將對象作為內(nèi)聯(lián)塊級彈性伸縮盒顯示

}

二伟墙、基本概念

采用Flex布局的元素,被稱為Flex容器(flex container)就乓,簡稱“容器”生蚁。其所有子元素自動成為容器成員邦投,成為Flex項目(Flex item)志衣,簡稱“項目”念脯。

結(jié)構(gòu)示意圖

容器默認存在兩根主軸:水平方向主軸(main axis)和垂直方向交叉軸(cross axis)徘铝,默認項目按主軸排列。

main start/main end:主軸開始位置/結(jié)束位置淹魄;

cross start/cross end:交叉軸開始位置/結(jié)束位置甲锡;

main size/cross size:單個項目占據(jù)主軸/交叉軸的空間缤沦;

三易稠、容器屬性

設(shè)置在容器上的屬性有6種驶社。

flex-direction

flex-wrap

flex-flow

justify-content

align-item

align-content

flex-direction屬性:決定主軸的方向(即項目的排列方向)

.box {

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

}

row(默認):主軸水平方向亡电,起點在左端份乒;

row-reverse:主軸水平方向或辖,起點在右端孝凌;

column:主軸垂直方向蟀架,起點在上邊沿片拍;

column-reserve:主軸垂直方向,起點在下邊沿苫纤。


主軸的4個方向

flex-wrap屬性:定義換行情況

默認情況下,項目都排列在一條軸線上栗弟,但有可能一條軸線排不下乍赫。


一條軸線排不下

.box{

? flex-wrap: nowrap | wrap | wrap-reverse;

}

nowrap(默認):不換行雷厂;


不換行nowrap

wrap:換行改鲫,第一行在上方钩杰;


換行,第一行在上

wrap-reverse:換行依痊,第一行在下方胸嘁。


換行群井,第一行在下

flex-flow屬性:flex-direction和flex-wrap的簡寫书斜,默認row nowrap

.box{

? ? flex-flow: || ;

}

justify-content屬性:定義項目在主軸上的對齊方式荐吉。

對齊方式與軸的方向有關(guān),本文中假設(shè)主軸從左到右。

.box {

? justify-content: start | end | flex-start | flex-end | center | left | right | space-between | space-around | space-evenly | stretch | safe | unsafe | baseline | first baseline | last baseline;

}

flex-start(默認值):左對齊;

左對齊


flex-end:右對齊陨亡;

右對齊


center:居中;

居中對齊


space-between:兩端對齊欲账,項目之間間隔相等赛不;

兩端對齊


space-around:每個項目兩側(cè)的間隔相等,即項目之間的間隔比項目與邊框的間隔大一倍。

兩側(cè)間隔相等

align-items屬性:定義在交叉軸上的對齊方式

對齊方式與交叉軸的方向有關(guān),假設(shè)交叉軸從下到上。

.box{

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

}

flex-start:起點對齊对供;

起點對齊


flex-end:終點對齊;

終點對齊


center:中點對齊;

中點對齊


baseline:項目的第一行文字的基線對齊;

基線對齊


stretch(默認值):如果項目未設(shè)置高度或設(shè)為auto,將占滿整個容器的高度。

align-content屬性:定義多根軸線的對齊方式

如果項目只有一根軸線顷锰,該屬性不起作用躺率。

所以,容器必須設(shè)置flex-wrap:···;

.box{

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

}

flex-start:與交叉軸的起點對齊馅精;


起點對齊


flex-end:與交叉軸的終點對齊;

終點對齊


center:與交叉軸的中點對齊渗常;

中點對齊


space-between:與交叉軸的兩端對齊,軸線之間的間隔平均分布;

軸線之間等間距


space-around:每根軸線兩側(cè)的間隔相等,即軸線之間的間隔比軸線與邊框的間隔大一倍;

軸線兩側(cè)等間距


stretch(默認值):軸線占滿整個交叉軸。

項目未設(shè)置高度時

有意思的是歼培,當(dāng)你不給項目設(shè)置高度但是給容器設(shè)置align-content不為stretch時躲庄,同一軸線上的項目的高度將等于項目中高度最高的項目笋庄。


四静暂、項目的屬性

設(shè)置在項目上的屬性也有6個洽蛀。

order

flex-grow

flex-shrink

flex-basis

flex

align-self

order屬性:定義項目的排列順序听绳。

數(shù)值越小头岔,排列越靠前峡竣,默認為0,可以是負值。

.item {

? ? order: <整數(shù)>;

}

展示效果不明顯,直接盜圖

flex-grow屬性:定義項目的放大比例

默認值為0,即如果空間有剩余,也不放大河狐。

可以是小數(shù),按比例占據(jù)剩余空間。


默認情況

.item{

? ? flex-grow: <數(shù)字>;

}

若所有項目的flex-grow的數(shù)值都相同,則等分剩余空間


等分剩余空間

若果有一個項目flex-grow為2猬膨,其余都為1谒所,則該項目占據(jù)剩余空間是其余的2倍


不等分占據(jù)

flex-shrink屬性:定義項目的縮小比例

默認值都為1,即如果空間不足將等比例縮小。

如果有一個項目的值為0,其他項目為1梆造,當(dāng)空間不足時贴捡,該項目不縮小屹逛。

負值對該屬性無效,容器不應(yīng)該設(shè)置flex-wrap蒿讥。

.item{

? ? flex-shrink: <非負整數(shù)>;

}

如果一個項目設(shè)置flex-shrink為0担敌;而其他項目都為1舷夺,則空間不足時,該項目不縮小疫萤。


設(shè)置flex-shrink為0的項目不縮小

如果所有項目都為0恒削,則當(dāng)空間不足時尾序,項目撐破容器而溢出。


不縮小

如果設(shè)置項目的flex-shrink不為0的非負數(shù)效果同設(shè)置為1携丁。


flex-basis屬性:定義在分配多余空間之前梦鉴,項目占據(jù)的主軸空間肥橙。

默認值為auto存筏,瀏覽器根據(jù)此屬性檢查主軸是否有多余空間。

.item{

? ? flex-basis:? ;

}

注意設(shè)置的flex-basis是分配多余空間之前項目占據(jù)的主軸空間予跌,如果空間不足則默認情況下該項目也會縮小匕得。


設(shè)置flex-basis為350px汁掠,但空間充足



空間不足考阱,項目縮小乞榨,小于設(shè)定值

flex屬性是flex-grow吃既,flex-shrink和flex-basis的簡寫

默認值為0 1 auto鹦倚,第一個屬性必須冀惭,后兩個屬性可選散休。

.item{

? ? flex: none | [];

}

可以用flex:auto;代替flex: 1 1 auto;戚丸;

可以用flex: none;代替flex: 0 0 auto;

####align-self屬性:允許單個項目與其他項目有不一樣的對齊方式

>默認值為auto猴鲫,表示繼承父元素的align-items屬性拂共,并可以覆蓋align-items屬性宜狐。

.item{

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

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市咱台,隨后出現(xiàn)的幾起案子回溺,更是在濱河造成了極大的恐慌混萝,老刑警劉巖逸嘀,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崭倘,死亡現(xiàn)場離奇詭異,居然都是意外死亡琅坡,警方通過查閱死者的電腦和手機榆俺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來碾盐,“玉大人毫玖,你說我怎么就攤上這事「斗悖” “怎么了阐滩?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵掂榔,是天一觀的道長装获。 經(jīng)常有香客問我穴豫,道長,這世上最難降的妖魔是什么秤涩? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮浊竟,結(jié)果婚禮上振定,老公的妹妹穿的比我還像新娘肉拓。我一直安慰自己暖途,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著欺栗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪消请。 梳的紋絲不亂的頭發(fā)上臊泰,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天七婴,我揣著相機與錄音察滑,去河邊找鬼贺辰。 笑死,一個胖子當(dāng)著我的面吹牛莽鸭,可吹牛的內(nèi)容都是我干的硫眨。 我是一名探鬼主播礁阁,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼姥闭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了越走?” 一聲冷哼從身側(cè)響起棚品,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎廊敌,沒想到半個月后铜跑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡骡澈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年锅纺,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秧廉。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡伞广,死狀恐怖蔽豺,靈堂內(nèi)的尸體忽然破棺而出沧侥,到底是詐尸還是另有隱情宴杀,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏节吮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一草丧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧煤禽,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽沮峡。三九已至望薄,卻和暖如春颁虐,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工隘击, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留州叠,地道東北人楼熄。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓缕粹,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子揭璃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

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

  • 2009年,W3C 提出了一種新的方案----Flex 布局呻惕,可以簡便盲泛、完整、響應(yīng)式地實現(xiàn)各種頁面布局官套。目前惋嚎,它已...
    丫3閱讀 563評論 0 0
  • flex 基本概念 flex 的核心的概念就是 容器 和 軸摆尝。容器包括外層的 父容器 和內(nèi)層的 子容器臼朗,軸包括 主...
    胡自鮮閱讀 1,022評論 1 1
  • 移動開發(fā)基本知識點 一.使用rem作為單位 html { font-size: 100px; } @media(m...
    橫沖直撞666閱讀 3,472評論 0 6
  • H5移動端知識點總結(jié) 閱讀目錄 移動開發(fā)基本知識點 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇閱讀 4,501評論 0 26
  • 之前聽人說,優(yōu)秀是一種習(xí)慣,我其實不懂是什么意思。 直到后來遇到了一些人一些事琅锻,這句話不經(jīng)意地就會冒出來,那時我才...
    大田兔子閱讀 176評論 2 5