彈性布局詳解——5個div讓你學會彈性布局


1 彈性布局簡介

  彈性布局,又稱“Flex布局”,是由W3C在2009年推出的一種布局方式。可以簡便、完整、響應式地實現各種頁面布局。而且已經得到所有主流瀏覽器的支持,我們可以放心大膽的使用。

       >>> 了解兩個基本概念,接下來會頻繁提到:

    ①  容器: 需要添加彈性布局的父元素;

    ②  項目: 彈性布局容器中的每一個子元素,稱為項目;

  >>> 了解兩個基本方向,這個牽扯到彈性布局的使用:

    ①  主軸: 在彈性布局中,我們會通過屬性規定水平/垂直方向為主軸;

    ②  交叉軸: 與主軸垂直的另一方向,稱為交叉軸。

2 彈性布局的使用
  ① 給父容器添加display: flex/inline-flex;屬性,即可使容器內容采用彈性布局顯示,而不遵循常規文檔流的顯示方式; 

  ② 容器添加彈性布局后,僅僅是容器內容采用彈性布局,而容器自身在文檔流中的定位方式依然遵循常規文檔流;

  ③ display:flex; 容器添加彈性布局后,顯示為塊級元素;display:inline-flex; 容器添加彈性布局后,顯示為行級元素;

  ④ 設為 Flex布局后,子元素的float、clear和vertical-align屬性將失效。但是position屬性,依然生效。

<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>

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM