六種CSS經典三欄布局方案

來源:互聯網
上載者:User
css是我們前端開發程式員必不可少的一門語言,能很好的掌握css能大大提高前端開發工作,本文主要介紹了CSS經典三欄布局方案,分享給大家。

三欄布局,顧名思義就是兩邊固定,中間自適應。三欄布局在開發十分常見

1. float布局

最簡單的三欄布局就是利用float進行布局。首先來繪製左、右欄:

    <style>      .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }    </style>            <p class="container">        <p class="left"></p>        <p class="right"></p>        <p class="main"></p>      </p>

此時可以得到左右兩欄分布:

接下來再來看中間欄如何處理。我們知道對於float元素,其會脫離文檔流,其他盒子也會無視這個元素。(但其他盒子內的文本依然會為這個元素讓出位置,環繞在周圍。)所以此時只需在container容器內添加一個正常的p,其會無視left和right,撐滿整個container,只需再加上margin為left right流出空間即可:

   <style>      .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }          .main {        background-color: green;        height: 200px;        margin-left: 120px;        margin-right: 120px;      }          .container {        border: 1px solid black;      }          <p class="container">      <p class="left"></p>      <p class="right"></p>      <p class="main"></p>      </p>

優勢:簡單

劣勢:中間部分最後載入,內容較多時影響體驗

2. BFC 規則

BFC(塊格式化上下文)規則規定:BFC不會和浮動元素重疊。所以如果將main元素設定為BFC元素即可:

    <style>      .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }          .main {        background-color: green;        height: 200px;        overflow: hidden;      }          <p class="container">        <p class="left"></p>        <p class="right"></p>        <p class="main"></p>      </p>

3. 聖杯布局

聖杯布局的核心是左、中、右三欄都通過float進行浮動,然後通過負值margin進行調整。

第一步,先來看下基本布局

    <style>        .left {            float: left;            width: 100px;            height: 200px;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            background-color: yellow;        }        .main {            float: left;            width: 100%;            height: 200px;            background-color: blue;        }    </style>    <body>        <p class="container">            <p class="main"></p>            <p class="left"></p>            <p class="right"></p>        </p>    </body>

此時看到的效果是:左、右兩欄被擠到第二行。這是因為main的寬度為100%。接下來我們通過調整左、右兩欄的margin來將左、中、右放在一行中:

        .left {            float: left;            width: 100px;            height: 200px;            margin-left: -100%;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            margin-left: -100px;            background-color: yellow;        }

第二步,將left的margin-left設定為-100%,此時左欄會移動到第一行的首部。然後再將right的margin-left設定為其寬度的負值:-100px,則右欄也會移動到和左、中欄一行中:

不過此時還沒有大功告成,我們試著在main中加入一些文字:

    <body>        <p class="container">            <p class="main">fjlskdjflkasjdfljasdljlsjdljsdjflksadj</p>            <p class="left"></p>            <p class="right"></p>        </p>    </body>

可以看到文字被壓住了,接下來就要解決這個問題。

第三步,給container一個padding,該padding應該正好等於左、右欄的寬度:

        .container {            padding-left: 100px;            padding-right: 100px;        }

此時看到的結果是左、中、右三欄都整體收縮了,但文字依然被壓住了。

第四步,給左、右兩欄加上相對布局,然後再通過設定left和right值向外移動:

        .left {            float: left;            width: 100px;            height: 200px;            margin-left: -100%;            position: relative;            left: -100px;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            margin-left: -100px;            position: relative;            right: -100px;            background-color: yellow;        }

到此為止,大功告成:

4. 雙飛翼布局

雙飛翼布局的前兩步和聖杯布局一樣,只是處理中間欄部分內容被遮擋問題的解決方案有所不同:

既然main部分的內容會被遮擋,那麼就在main內部再加一個content,通過設定其margin來避開遮擋,問題也就可以解決了:

<!DOCTYPE html><html lang="en"><head>    <style>        .main {        float: left;        width: 100%;        }        .content {        height: 200px;        margin-left: 110px;        margin-right: 220px;        background-color: green;        }                .main::after {        display: block;        content: '';        font-size: 0;        height: 0;        clear: both;        zoom: 1;        }    .left {        float: left;        height: 200px;        width: 100px;        margin-left: -100%;        background-color: red;    }    .right {        width: 200px;        height: 200px;        float: left;        margin-left: -200px;        background-color: blue;    }       </style></head><body>    <p class="main">        <p class="content"></p>    </p>    <p class="left"></p>    <p class="right"></p></body></html>

唯一需要注意的是,需要在main後面加一個元素來清除浮動。

5. flex布局

flex布局是趨勢,利用flex實現三欄布局也很簡單,不過需要注意瀏覽器安全色性:

        <style type="text/css">            .container {                display: flex;                flex-direction: row;            }            .middle {                height: 200px;                background-color: red;                flex-grow: 1;            }            .left {                height: 200px;                order: -1;                margin-right: 20px;                background-color: yellow;                flex: 0 1 200px;            }            .right {                height: 200px;                margin-left: 20px;                background-color: green;                flex: 0 1 200px;            }        </style>    </head>    <body>        <p class="container">            <p class="middle">fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj</p>            <p class="left"></p>            <p class="right"></p>        </p>    </body>

有幾點需要注意一下:

  1. main要首先載入就必須寫在第一位,但因為left需要顯示在最左側,所以需要設定left的order為-1

  2. flex屬性的完整寫法是:flex: flex-grow flex-shrink flex-basis 。這也是flex實現三欄布局的核心,main設定flex-grow為1,說明多餘空間全部給main,而空間不夠時,僅縮小left right部分,同時因為指定了left right部分的flex-basis,所以指定了兩者的寬度,保證其顯示效果

6. 絕對位置

絕對位置的方式也比較簡單,而且可以優先載入主體:

        <style type="text/css">            .container {            }            .middle {                position: absolute;                left: 200px;                right: 200px;                height: 300px;                background-color: yellow;            }            .left {                position: absolute;                left: 0px;                width: 200px;                height: 300px;                background-color: red;            }            .right {                position: absolute;                right: 0px;                width: 200px;                background-color: green;                height: 300px;            }        </style>    </head>    <body>        <p class="container">            <p class="middle">fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj</p>            <p class="left"></p>            <p class="right"></p>        </p>    </body>

以上內容就收關於六種CSS經典三欄的布局方案,希望能協助到大家。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.