css-彈性布局彈布局(Flex布局)


在網頁制作過程中,布局是我們最重要的一個環節。可以說布局的好壞直接影響到整個網頁的成敗!布局成,則事半功倍;布局敗,則事倍功半。

隨着移動互聯的到來,響應式網站風靡。這也就興起了一種新興的布局方式——彈性布局。

取代我們之前“display+float+position”的布局形式,采用全新的彈性布局,會讓你的網站如絲般順滑!

今天,就讓我們一起來學習一下彈性布局,讓我們用5個div玩轉彈性布局吧~

 

彈性布局簡介


 

1:所有瀏覽器都支持

2:容器和項目

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

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

 

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

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

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

 

彈性布局使用


① 給父容器添加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;
                
}

 

 

 作為父容器的6大屬性


 

 

② flex-wrap屬性定義,如果一條軸線排不下,如何換行。

    nowrap(默認):不換行。當容器寬度不夠時,每個項目會被擠壓寬度;

   wrap: 換行,並且第一行在容器最上方;

    wrap-reverse: 換行,並且第一行在容器最下方。

 

 

 ③ flex-flow 是flex-direction和flex-wrap的縮寫形式,默認值為:flex-flow: row wrap; 不做過多解釋

 ④ justify-content屬性定義了項目在主軸上的對齊方式。  >>> 此屬性與主軸方向息息相關。

           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(默認值):軸線占滿整個交叉軸。

 

 

  Android 作用於子項目的6大屬性:寫到style里面


 

①  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屬性值。

 

 

讓我們愉快的拋棄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