如何利用flex布局實現各種布局

flex布局是一種很方便的布局,不用自己設置同行的div的高度相等,它們即可高度相等,并且可以方便的實現柵格系統等。下面是幾種常見的布局,看flex如何實現:

兩列等高布局:

左邊固定寬度,右邊占據剩余寬度:

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex-basis: 100px;
}
    .gridCell2{
        background-color: #3355D0;
        flex-basis:calc(100% - 100px);
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中沒有塊作用域的概念,所以下列的代碼中的i可以在全局環境中訪問,但這樣會有一個弊端:污染了全局環境,因為在大型工程中,有可能會導致變量沖突。</p></div>
    <div class="gridCell2"><h1>標題</h1></div>
</div>
</body>

實現效果:

Paste_Image.png

可以看到上述代碼實現了一個左邊固定寬度,右邊占據剩余寬度的布局,并且高度相等。
原理:設置父容器為flex,子元素中左邊設置flex-basis屬性寬度為固定寬度,另外一個子元素的flex-basis屬性設置為100%減去這個固定寬度即可。

柵格系統:

在Bootstrap中可以很方便的使用柵格系統引入各個div的寬度劃分,如果不使用柵格系統,利用flex也是很容易實現的。

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex: 1;
}
    .gridCell2{
        background-color: #3355D0;
        flex: 4;
    }
    .gridCell3{
        background-color: #b6d0ba;
        flex: 1;
    }
    .gridCell4{
        background-color: #d064b9;
        flex: 1;
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中沒有塊作用域的概念,所以下列的代碼中的i可以在全局環境中訪問,但這樣會有一個弊端:污染了全局環境,因為在大型工程中,有可能會導致變量沖突。</p></div>
    <div class="gridCell2"><p>文字1</p></div>
    <div class="gridCell3"><p>文字2</p></div>
    <div class="gridCell4"><p>文字3</p></div>
</div>
</body>

效果圖:

Paste_Image.png

如上,flex屬性為flex-grow flex-shrink flex-basis的簡寫屬性,當只有一個非負整數時,表示flex-grow的值,另外兩個值為 1和0%;flex-grow是項目的放大比例,所以上述四個div的寬度以1:4:1:1的形式呈現。
另一種情況:flex屬性為百分比的情況

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex: 10%;
}
    .gridCell2{
        background-color: #3355D0;
        flex: 40%;
    }
    .gridCell3{
        background-color: #b6d0ba;
        flex: 10%;
    }
    .gridCell4{
        background-color: #d064b9;
        flex: 40%;
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中沒有塊作用域的概念,所以下列的代碼中的i可以在全局環境中訪問,但這樣會有一個弊端:污染了全局環境,因為在大型工程中,有可能會導致變量沖突。</p></div>
    <div class="gridCell2"><p>文字1</p></div>
    <div class="gridCell3"><p>文字2</p></div>
    <div class="gridCell4"><p>文字3</p></div>
</div>
</body>

效果圖:

Paste_Image.png

當flex屬性只有一個百分數時,表示的是flex-basis,其他的兩個值flex-grow和flex-shrink均為0.

圣杯布局:

Paste_Image.png
<style>
    *{
        margin: 0;
        padding:0;
    }
    body{
        display: flex;
        flex-direction: column;
    }
    .header,.footer{
        flex: 1;
        background-color: #8591f7;
    }
    .container{
        flex:1;
        display: flex;
    }
    .left{
        flex-basis:100px;
        background-color: #449fdb;
    }
    .right{
        flex-basis: 100px;
        background-color: #3355D0;
    }
    .main{
        flex-basis: calc(100% - 200px);
        background-color: #6f7178;
    }
</style>
<body>
<div class="header"><h1>標題</h1></div>
<div class="container">
    <div class="left"><p>JS中沒有塊作用域的概念,所以下列的代碼中的i可以在全局環境中訪問,但這樣會有一個弊端:污染了全局環境,因為在大型工程中,有可能會導致變量沖突。</p></div>
    <div class="main"><p>文字1</p></div>
    <div class="right"><p>文字2</p></div>
</div>
<div class="footer"><p>頁腳</p></div>
</body>

該布局需要設置兩個flex,一個垂直方向,一個水平方向,垂直方向的容器為body,水平方向的容器為container。垂直方向的三個子元素分別設置flex屬性為1,水平方向的三個子元素分別各自設置flex-basis。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • CSS 3中彈性盒布局的最新版概述 在CSS 3中,CSS Flexible Box模塊為一個非常重要的模塊,該模...
    吾名無雙閱讀 1,248評論 0 5
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,806評論 1 92
  • H5移動端知識點總結 閱讀目錄 移動開發基本知識點 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇閱讀 4,627評論 0 26
  • 移動開發基本知識點 一.使用rem作為單位 html { font-size: 100px; } @media(m...
    橫沖直撞666閱讀 3,514評論 0 6
  • 前言 FlexBox是css3的一種新的布局方式,天生為解決布局問題而存在的它,比起傳統的布局方式,我們使用Fle...
    zevei閱讀 1,438評論 23 3