轉載請註明出處:葡萄城官網,葡萄城爲開發者提供專業的開發工具、解決方案和服務,賦能開發者。css
原文出處:https://www.sitepoint.com/flexbox-css-flexible-box-layout/html
近幾年,CSS領域出現了一些複雜的專用佈局工具,用以代替原有的諸如使用表格、浮動和絕對定位之類的各類變通方案。Flexbox,或者說是彈性盒子佈局模塊(Flexible Box Layout Module)是這些新佈局工具中的第一個,接着是CSS網格佈局模塊(CSS Grid Layout Module)。咱們會在本文給出一個易於理解的flexbox入門介紹。css3
隨着CSS網格佈局的引入,你可能會問flexbox佈局是否真的還有必要。雖然它們所能作的事情有一些重疊,但其各自在CSS佈局中有着很是特別的目的。通常來講,flexbox在一維場景(好比,一串相似的元素)下有最佳應用,而網格是二維場景下理想的佈局方案(例如整個頁面的元素)。git
即使如此,flexbox仍能夠用於整個頁面的佈局,這樣它能爲那些還不支持網格佈局的瀏覽器提供合適的兼容處理。(必須認可,網格佈局正在大多數現代瀏覽器中快速獲得支持,不過對flexbox的支持仍然更爲普遍,因此若是你想讓你的佈局在稍微老舊的瀏覽器中也生效,使用flexbox做爲網格佈局的降級方案是很容易的)。瀏覽器
使用Flexbox的好處ide
flexbox的一些好處是:工具
爲了闡述其多樣的屬性和可能性,讓咱們假設下面有這樣的佈局用例:佈局
<div class="example"> <header> header content here </header> <main class="main"> <nav> nav content here </nav> <div class="content"> main content here </div> <aside> aside content here </aside> </main> <footer> footer content here </footer> </div>
首先,是把元素一塊兒放進.main裏,好比,<nav>和<aside>。若是沒有flexbox,咱們可能會把三個元素所有進行浮動,但想讓它按理想的方式工做顯得並不直觀。並且,按傳統的方式作這件事會出現一個衆所周知的問題:每一列僅僅和它的內容同樣高。所以,你可能須要把三個元素都設置爲統一的高度,或者使用某種黑科技。開發工具
讓flexbox來救場吧。flex
讓咱們Flex
flexbox的要點是出如今display屬性上的flex值,它須要被設置在容器元素上。如此設置會讓它的子元素變成「彈性項目(flex item)」。這些彈性項目擁有一些易於使用的默認屬性。好比,它們被緊挨着放置,那些沒有特別指明寬度的元素自動佔滿了剩餘的空間。
所以,若是你給.main設置了display:flex,它的子元素.content就被自動擠在<nav>和<aside>之間。不須要再多餘的計算,多麼方即是吧?做爲附加獎賞,全部三個元素神奇地擁有了相同的高度。
.main { display: flex; }
請查看下面的例子,包含了全部的細節:flexbox-demo-1。
項的順序:Flebox的order屬性
另一個flexbox的能力,是可以輕鬆改變元素的顯示順序。讓咱們假設你爲一個客戶製做了上面的佈局,而她如今想要.content出如今<nav>以前。
一般,你須要深刻到HTML源碼中去,在那裏改變元素的順序。而有了Flexbox,你能夠徹底使用CSS完成這項任務。只需把.content的order屬性設置爲-1,那麼這一列就會出如今前面,這本例就是最左邊。
.main { display: flex; } .content { order: -1; }
本例中,你不須要改變其餘列的order。例子在flexbox-demo-2。
若是你傾向於顯式地爲每一列指定order,你能夠將.content的order設爲1,把<nav>的order設爲2,把<aside>的設爲3。
HTML源碼獨立於CSS的Flexbox樣式
但你的客戶並不知足。她想讓<footer>成爲頁面的第一個元素,顯示在<header>以前。那好,一樣的,flexbox是你的朋友(雖然像在此例中,可能你得跟你的客戶好好談談,而不是跟隨指示)。由於你不只要重排列內部元素,還要重排外部的,display:flex規則將被設置在<div class="example">之上。注意這裏是如何在頁面中嵌套使用flex容器來達到你想要的效果的。
由於<header>,<main class="main">和<footer>相互堆疊着,你須要首先設置一個垂直上下文,它可以經過設置flex-direction:column來快速完成。還有,<footer>的order被設置爲-1,如此一來它就出如今頁面的最上頭。就這麼簡單。
.example { display: flex; flex-direction: column; } footer { order: -1; }
因此,若是你想把一行元素修改成一列,或者相反,你可使用flex-direction屬性,並設置它相應地爲column或row(row是默認值)。
完整的例子在flexbox-demo-3。
然而,強大的能力也到來了更多的責任:謹記,一些用戶可能會使用鍵盤來導航你的基於flexbox的網站,若是你HTML源碼中元素的順序和屏幕上顯示的有所出入,那麼無障礙訪問的能力就成爲須要認真對待的問題。若是想了解得更多,請不要錯過HTML源碼順序 vs CSS顯示順序,網站無障礙訪問和易用性的專家Adrian Roselli針對這個問題給出了深刻討論。
如何在Flexbox中對齊子項
Flexbox能很是直觀地處理子項的水平對齊和垂直對齊。
你可使用align-items對flex容器中的全部子項設置統一的對齊。若是你想給個別元素設置不一樣的對齊方式,使用align-self。元素的對齊方式跟它所在父容器的flex-direction有關。若是它的值是row(意味着元素水平排列),對齊方式是指在垂直軸上。若是flex-direction被設置爲column(意味着元素垂直排列),對齊方式就是指在水平軸上。
例如,你讓一些元素在容器中分別有不一樣的對齊方式,你須要:
.example { display: flex; flex-direction: column; } .red { align-self: center; } .blue { align-self: flex-start; } .pink { align-self: flex-end; }
試試在下面的例子中,把父容器的flex-direction在row和column之間切換,看看它們引發的實時變化。
若是想要容器中全部的元素有統一的對齊方式,你能夠在容器上使用align-items。能夠的值有center,flex-start,flex-end,stretch(默認值:子項被拉伸以適應它們的容器)和baseline(子項被放置在父容器的baseline上)。
.example { display: flex; align-items: center; }
像往常同樣,試着把父容器的flex-direction在row和column之間切換,看看它們如何影響着你設置align-items值時所發生的做用。
在Flexbox裏兩端對齊
另外一個控制對齊的屬性是justify-content,當你想讓多個元素等分空間時很是有用。
可接受的值有:center,flex-start,flex-end, space-between(元素利用主軸之間的空間而排布)和space-around(元素利用主軸以前、之間和以後的空間而排布)。
例如,在以前你一直使用的簡單HTML模板裏,你能夠在<main>裏找到三個元素:<nav>,.content和<aside>。以前,它們都被擠在頁面的左邊。若是你想讓它們之間有一些空間,可是不讓第一個元素的左邊有空間,也不想讓最後一個元素的右邊有空間,你能夠把.main(即它們的父容器)裏的justify-content設置爲space-between。
.main { display: flex; justify-content: space-between; }
也試一下設置爲space-around,觀察不一樣的結果。例子在flexbox-demo-6。
在上面的例子中,我一樣把<header>中的文字水平和垂直對齊了,分別是把justify-content(水平居中)和align-items(垂直居中)都設置爲center。
header { height: 100vh; display: flex; justify-content: center; align-items: center; }
Flexbox中彈性子項的大小
使用flex屬性,你可以對照flex容器中其餘元素來控制彈性子項的大小。
這個屬性是如下獨立屬性的簡寫:
例如,想獲得三個等寬的列,只需給每一列設置flex:1,其餘什麼都不用作:
nav, aside, .content { flex: 1; }
若是你須要.content佔據<nav>和<aside>的兩倍寬,那麼就把.content設爲flex:2,讓其餘兩個爲1。
那僅僅是對flex屬性最簡單的應用。一樣能夠設置flex-grow,flex-shrink和flex-basis這些值,不過那超出本文的話題範圍了。
進一步的資源
若是你準備好繼續前進,並想學着精通flexbox的更多東西,請查看下面的資源:
總結
如你所見,若是咱們想控制元素在網頁中的佈局,flexbox可讓咱們的生活更加輕鬆。它很是穩固和可靠,讓之前那些咱們天天使用的諸如使 讓容器坍縮之類的奇技淫巧,成爲了過去。
像咱們說的,現在,在針對整個頁面進行佈局時,CSS網格是更好的方案,但咱們仍然值得去了解flexbox能作的那些事情。flexbox的最佳應用場景,體如今對元素的一維排列上,但若是有須要,它也能在稍老舊的瀏覽器中,爲CSS網格佈局提供方便的替代方案。