在網頁制作過程中,布局是我們最重要的一個環節。可以說布局的好壞直接影響到整個網頁的成敗!布局成,則事半功倍;布局敗,則事倍功半。 隨着移動互聯的到來,響應式網站風靡。這也就興起了一種新興的布局方式——彈性布局。取代我們之前“display+float+position”的布局形式,采用全新的彈性布局,會讓你的網站如絲般順滑! 今天,就讓我們一起來學習一下彈性布局,讓我們用5個div玩轉彈性布局吧~
本章內容將詳細介紹Android事件的具體處理及常見事件。
1 彈性布局簡介 |
彈性布局,又稱“Flex布局”,是由W3C老大哥於2009年推出的一種布局方式。可以簡便、完整、響應式地實現各種頁面布局。而且已經得到所有主流瀏覽器的支持,我們可以放心大膽的使用。
>>> 了解兩個基本概念,接下來會頻繁提到:
① 容器: 需要添加彈性布局的父元素;
② 項目: 彈性布局容器中的每一個子元素,稱為項目;
>>> 了解兩個基本方向,這個牽扯到彈性布局的使用:
① 主軸: 在彈性布局中,我們會通過屬性規定水平/垂直方向為主軸;
② 交叉軸: 與主軸垂直的另一方向,稱為交叉軸。
2 彈性布局的使用 |
① 給父容器添加display: flex/inline-flex;屬性,即可使容器內容采用彈性布局顯示,而不遵循常規文檔流的顯示方式;
② 容器添加彈性布局后,僅僅是容器內容采用彈性布局,而容器自身在文檔流中的定位方式依然遵循常規文檔流;
③ display:flex; 容器添加彈性布局后,顯示為塊級元素;
display:inline-flex; 容器添加彈性布局后,顯示為行級元素;
④ 設為 Flex布局后,子元素的float、clear和vertical-align屬性將失效。但是position屬性,依然生效。
2.1代碼實例
<div id="div"> <div class="div1">1</div> <div class="div2">2</div> <div class="div3">3</div> <div class="div4">4</div> </div>
#div{ width: 400px; height: 400px; background-color: yellow; display: flex; } #div div{ width: 100px; height: 100px; background-color: blue; color: white; font-size: 30px; }
五個簡單的div,只給父容器添加了display: flex;屬性,就可以讓容器內部打破原有文檔流模式,展現為彈性布局。
簡單的了解一下彈性布局后,我們來詳解一下配合“display: flex;”使用的12大屬性。其中,12個屬性分為兩類,6個作用於父容器,6個作用於子項目。
3 作為父容器的6大屬性 |
① flex-direction屬性決定主軸的方向(即項目的排列方向)。
row(默認值): 主軸為水平方向,起點在左端;
row-reverse: 主軸在水平方向,起點在右端 ;
column:主軸為垂直方向,起點在上沿。
column-reverse:主軸為垂直方向,起點在下沿。
② flex-wrap屬性定義,如果一條軸線排不下,如何換行。
nowrap(默認):不換行。當容器寬度不夠時,每個項目會被擠壓寬度;
wrap: 換行,並且第一行在容器最上方;
wrap-reverse: 換行,並且第一行在容器最下方。
③ flex-flow 是flex-direction和flex-wrap的縮寫形式,默認值為:flex-flow: row wrap; 不做過多解釋
④ justify-content屬性定義了項目在主軸上的對齊方式。
>>> 此屬性與主軸方向息息相關。
主軸方向為:row-起點在左邊,row-reverse-起點在右邊, column-起點在上邊,column-reverse-起點在下邊
flex-start(默認值): 項目位於主軸起點。
flex-end:項目位於主軸終點。
center: 居中
space-between:兩端對齊,項目之間的間隔都相等。(開頭和最后的項目,與父容器邊緣沒有間隔)
space-around:每個項目兩側的間隔相等。所以,項目之間的間隔比項目與邊框的間隔大一倍。(開頭和最后的項目,與父容器邊緣有一定的間隔)
⑤ align-items屬性定義項目在交叉軸上如何對齊。
flex-start:交叉軸的起點對齊。
flex-end:交叉軸的終點對齊。
center:交叉軸的中點對齊。
baseline: 項目的第一行文字的基線對齊。(文字的行高、字體大小會影響每行的基線)
stretch(默認值):如果項目未設置高度或設為auto,將占滿整個容器的高度。
⑥ align-content屬性定義了多根軸線的對齊方式。如果項目只有一根軸線,該屬性不起作用。
(當項目換為多行時,可使用align-content取代align-items)
flex-start:與交叉軸的起點對齊。
flex-end:與交叉軸的終點對齊。
center:與交叉軸的中點對齊。
space-between:與交叉軸兩端對齊,軸線之間的間隔平均分布。
space-around:每根軸線兩側的間隔都相等。所以,軸線之間的間隔比軸線與邊框的間隔大一倍。
stretch(默認值):軸線占滿整個交叉軸。
4 Android 作用於子項目的6大屬性 |
① order屬性定義項目的排列順序。數值越小,排列越靠前,默認為0。
② flex-grow屬性定義項目的放大比例,默認為0,即如果存在剩余空間,也不放大。
③ flex-shrink屬性定義了項目的縮小比例,默認為1,即如果空間不足,該項目將縮小。
④ flex-basis定義項目占據的主軸空間。(如果主軸為水平,則設置這個屬性,相當於設置項目的寬度。 原width將會失效。)
⑤ flex屬性是flex-grow, flex-shrink 和 flex-basis的簡寫,默認值為0 1 auto。后兩個屬性可選。
此屬性有兩個快捷設置:auto=(1 1 auto)/none=(0 0 auto)
⑥ align-self:定義單個項目自身在交叉軸上的排列方式,可以覆蓋掉容器上的align-items屬性。
屬性值:與align-items相同,默認值為auto,表示繼承父容器的align-items屬性值。
好了,相信到這里,所有同學都能夠理解flex彈性布局了吧~~學習一個新知識,字不如表,表不如圖。希望這5個div的圖解,能夠讓所有同學深刻的理解Flex彈性布局~接下來,讓我們愉快的拋棄Float、拋棄Position,一起擁抱Flex吧!!
最后,所有的源碼附上,需要的同學自行測試哦~
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
#div{
width: 500px;
height: 400px;
background-color: yellow;
display: flex;
/*flex-direction: column-reverse;*/
/*flex-wrap: wrap;*/
/*justify-content: space-around;*/
/*align-items: stretch;*/
/*align-content: stretch;*/
}
#div div{
width: 100px;
height: 100px;
background-color: blue;
color: white;
font-size: 30px;
/*flex-shrink: 0;*/
}
#div .div1{
/*font-size: 48px;*/
/*order: 1;*/
/*flex-grow: 1;*/
/*flex-shrink: 0;*/
/*background-color: red;*/
}
#div .div3{
/*flex-grow: 2;*/
background-color: green;
/*flex-basis: 200px;*/
align-self: flex-end;
}
</style>
</head>
<body>
<div id="div">
<div class="div1">1</div>
<div class="div2">2</div>
<div class="div3">3</div>
<div class="div4">4</div>
</div>
</body>
</html>