亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS經典三欄布局方案(6種方法)

2024-07-11 08:58:48
字體:
來源:轉載
供稿:網友

本文介紹了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>            <div class="container">        <div class="left"></div>        <div class="right"></div>        <div class="main"></div>      </div>

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

 

接下來再來看中間欄如何處理。我們知道對于float元素,其會脫離文檔流,其他盒子也會無視這個元素。(但其他盒子內的文本依然會為這個元素讓出位置,環繞在周圍。)所以此時只需在container容器內添加一個正常的div,其會無視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;      }          <div class="container">      <div class="left"></div>      <div class="right"></div>      <div class="main"></div>      </div>

 

優勢:簡單

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

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;      }          <div class="container">        <div class="left"></div>        <div class="right"></div>        <div class="main"></div>      </div>

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>        <div class="container">            <div class="main"></div>            <div class="left"></div>            <div class="right"></div>        </div>    </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>        <div class="container">            <div class="main">fjlskdjflkasjdfljasdljlsjdljsdjflksadj</div>            <div class="left"></div>            <div class="right"></div>        </div>    </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>    <div class="main">        <div class="content"></div>    </div>    <div class="left"></div>    <div class="right"></div></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>        <div class="container">            <div class="middle">fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj</div>            <div class="left"></div>            <div class="right"></div>        </div>    </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>        <div class="container">            <div class="middle">fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj</div>            <div class="left"></div>            <div class="right"></div>        </div>    </body>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美夫妻性生活xx| 国产精品久久久久久久久久新婚| 91久久精品美女| 日韩av影院在线观看| 欧美一级bbbbb性bbbb喷潮片| 一道本无吗dⅴd在线播放一区| 色婷婷综合久久久久中文字幕1| 久久99国产综合精品女同| 国产成人午夜视频网址| 成人性教育视频在线观看| 成人国产在线激情| 亚洲第一av网站| 久久精品国产2020观看福利| 北条麻妃一区二区三区中文字幕| 精品女同一区二区三区在线播放| 亚洲欧洲日产国产网站| 欧美老女人在线视频| 亚洲黄色www| www.日韩av.com| 亚洲男人第一av网站| 日韩av在线免播放器| 亚洲欧美国产制服动漫| 国产精品免费一区二区三区都可以| 亚洲人成电影网站色| 97视频在线观看视频免费视频| 色一区av在线| 久久精品色欧美aⅴ一区二区| 亚洲欧洲免费视频| 亚洲第一视频在线观看| 搡老女人一区二区三区视频tv| 国产精品欧美日韩久久| 91精品国产高清久久久久久| 欧美成人全部免费| 日韩精品中文字幕在线| 欧美黑人性生活视频| 日韩欧美国产骚| 国产日本欧美一区二区三区| 有码中文亚洲精品| 在线午夜精品自拍| 国产亚洲一区二区在线| 日本最新高清不卡中文字幕| 中文字幕日韩av电影| 国产亚洲精品美女久久久| 91精品久久久久久久久中文字幕| 日韩av不卡电影| 97涩涩爰在线观看亚洲| 最近2019中文字幕在线高清| 97色在线播放视频| 国产精品福利在线观看网址| 欧美资源在线观看| 亚洲自拍偷拍第一页| 久久影视电视剧免费网站清宫辞电视| 日韩国产精品一区| 美女国内精品自产拍在线播放| 亚洲国模精品私拍| 精品美女国产在线| 日韩精品小视频| 欧美亚洲国产成人精品| 日韩精品小视频| 欧美日韩在线视频一区二区| 亚洲国产精品成人av| 国产精品爽爽ⅴa在线观看| 国产精品jizz在线观看麻豆| 亚洲欧美日韩第一区| 欧美亚洲激情在线| 亚洲高清一二三区| 亚洲老头同性xxxxx| 色系列之999| 国产视频久久久久| 欧洲精品在线视频| 国产美女精品视频| 亚洲资源在线看| 国产精品久久久av久久久| 高清一区二区三区四区五区| 97超碰色婷婷| 国产视频精品xxxx| 欧美成人黑人xx视频免费观看| 日韩一区二区精品视频| 亚洲日本中文字幕免费在线不卡| 国产精品久久在线观看| 91人人爽人人爽人人精88v| 久久久久亚洲精品国产| 狠狠爱在线视频一区| 欧美激情免费视频| 一区二区三区亚洲| 自拍偷拍亚洲区| 国产日韩中文在线| 亚洲欧美变态国产另类| 日韩高清电影免费观看完整版| 国产丝袜一区二区三区免费视频| 在线观看欧美日韩| 成人黄色av免费在线观看| 2019日本中文字幕| 欧美国产视频日韩| 1769国内精品视频在线播放| 国产精品中文在线| 亚洲成人中文字幕| 中文字幕亚洲一区二区三区五十路| 欧美性猛交xxxx免费看久久久| 久久人人97超碰精品888| 久久久久久网站| 高清在线视频日韩欧美| 91日本视频在线| 日韩视频免费在线观看| 亚洲国产成人精品电影| 久久免费视频观看| 国产精品久久久久久av福利| 色偷偷av一区二区三区乱| 色婷婷综合久久久久中文字幕1| 久久成人人人人精品欧| 8x海外华人永久免费日韩内陆视频| 久久香蕉频线观| 91精品啪在线观看麻豆免费| 国产精品欧美日韩一区二区| 色黄久久久久久| 日韩中文在线视频| 成人欧美一区二区三区在线湿哒哒| 色无极亚洲影院| 久久久久久久亚洲精品| 国产精品∨欧美精品v日韩精品| 51ⅴ精品国产91久久久久久| 久久深夜福利免费观看| 亚洲福利小视频| 青青久久av北条麻妃海外网| 欧美激情久久久久| 欧美激情免费观看| 午夜欧美大片免费观看| 91精品国产色综合久久不卡98| 久久精品视频播放| 亚洲成av人影院在线观看| 国产精品女人网站| 中文字幕在线观看日韩| 影音先锋欧美在线资源| 中文字幕在线视频日韩| 久久久精品美女| 欧美视频在线视频| 国产精品入口免费视频一| 久久青草福利网站| 欧美激情视频一区二区三区不卡| 91在线观看免费高清完整版在线观看| 68精品国产免费久久久久久婷婷| 国产成人久久精品| 亚洲美女性视频| 狠狠躁夜夜躁久久躁别揉| 欧美日韩激情视频| 国产精品丝袜视频| 欧美在线视频免费观看| 亚洲免费高清视频| 国产精品普通话| 欧美国产在线视频| 欧美中文在线视频| 国产成人jvid在线播放| 国产精品扒开腿做爽爽爽男男| 国产91免费看片| 久久精品电影网站| 亚洲女人天堂成人av在线| 欧美性xxxx在线播放| 久久国产精品99国产精| 欧美视频在线免费看| 亚洲无线码在线一区观看| 播播国产欧美激情| 国产欧美 在线欧美| 在线日韩av观看| 成人在线观看视频网站|