css怎么實現(xiàn)三列布局

這篇文章主要介紹css怎么實現(xiàn)三列布局,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

公司主營業(yè)務(wù):網(wǎng)站設(shè)計制作、網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出永新免費做網(wǎng)站回饋大家。

css實現(xiàn)三列布局的方法:1、float浮動布局;2、絕對定位布局;3、flexbox彈性布局,存在IE上兼容性問題,只能支持IE9以上;4、table表格布局,不利于搜索引擎抓取信息;5、gird網(wǎng)格布局,兼容性差。

本教程操作環(huán)境:windows7系統(tǒng)、CSS3&&HTML5版、Dell G3電腦。

三欄布局,顧名思義就是兩邊固定,中間自適應。三欄布局在實際的開發(fā)十分常見,比如淘寶網(wǎng)的首頁,就是個典型的三欄布局:即左邊商品導航和右邊導航固定寬度,中間的主要內(nèi)容隨瀏覽器寬度自適應。

css怎么實現(xiàn)三列布局

我們不妨假定這樣一個布局:高度已知,其中左欄、右欄寬度各為300px,中間自適應,可以通過幾種方法來實現(xiàn)?以及各自的優(yōu)缺點是什么?

一、浮動布局

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Layout</title>
    <style media="screen">
        html * {
            padding: 0;
            margin: 0;
        }
        .layout article div {
            min-height: 150px;
        }
    </style>
</head>
<body>
    <!--浮動布局  -->
    <section class="layout float">
        <style media="screen">
            .layout.float .left {
                float: left;
                width: 300px;
                background: red;
            }
            .layout.float .center {
                background: yellow;
            }
            .layout.float .right {
                float: right;
                width: 300px;
                background: blue;
            }
        </style>
        <h2>三欄布局</h2>
        <article class="left-right-center">
            <div class="left"></div>
            <div class="right"></div> // 右欄部分要寫在中間內(nèi)容之前
            <div class="center">
                <h3>浮動解決方案</h3>
                1.這是三欄布局的浮動解決方案; 2.這是三欄布局的浮動解決方案; 3.這是三欄布局的浮動解決方案; 4.這是三欄布局的浮動解決方案; 5.這是三欄布局的浮動解決方案; 6.這是三欄布局的浮動解決方案;
            </div>
        </article>
    </section>
</body>
</html>

這種布局方式,dom結(jié)構(gòu)必須是先寫浮動部分,然后再中間塊,否則右浮動塊會掉到下一行。
浮動布局的優(yōu)點就是比較簡單,兼容性也比較好。但浮動布局是有局限性的,浮動元素脫離文檔流,要做清除浮動,這個處理不好的話,會帶來很多問題,比如父容器高度塌陷等。

二、絕對定位布局

<!--絕對布局  -->
 <section class="layout absolute">
     <style>
         .layout.absolute .left-center-right>div{
             position: absolute;//三塊都是絕對定位
         }
         .layout.absolute .left {
             left:0;
             width: 300px;
             background: red;
         }
         .layout.absolute .center {
             right: 300px;
             left: 300px;//離左右各三百
             background: yellow;
         }
         .layout.absolute .right {
             right: 0;
             width: 300px;
             background: blue;
         }
     </style>
     <h2>三欄布局</h2>
     <article class="left-center-right">
         <div class="left"></div>
         <div class="center">
             <h3>絕對定位解決方案</h3>
             1.這是三欄布局的浮動解決方案; 2.這是三欄布局的浮動解決方案; 3.這是三欄布局的浮動解決方案; 4.這是三欄布局的浮動解決方案; 5.這是三欄布局的浮動解決方案; 6.這是三欄布局的浮動解決方案;
         </div>
         <div class="right"></div>
     </article>
 </section>

絕對定位布局優(yōu)點就是快捷,設(shè)置很方便,而且也不容易出問題。缺點就是,容器脫離了文檔流,后代元素也脫離了文檔流,高度未知的時候,會有問題,這就導致了這種方法的有效性和可使用性是比較差的。

三、flexbox布局

<!--flexbox布局-->
<section class="layout flexbox">
    <style>
        .layout.flexbox .left-center-right{
            display: flex;
        }
        .layout.flexbox .left {
            width: 300px;
            background: red;
        }
        .layout.flexbox .center {
            background: yellow;
            flex: 1;
        }
        .layout.flexbox .right {
            width: 300px;
            background: blue;
        }
    </style>
    <h2>三欄布局</h2>
    <article class="left-center-right">
        <div class="left"></div>
        <div class="center">
            <h3>flexbox解決方案</h3>
            1.這是三欄布局的浮動解決方案; 2.這是三欄布局的浮動解決方案; 3.這是三欄布局的浮動解決方案; 4.這是三欄布局的浮動解決方案; 5.這是三欄布局的浮動解決方案; 6.這是三欄布局的浮動解決方案;
        </div>
        <div class="right"></div>
    </article>
</section>

flexbox布局是css3里新出的一個,它就是為了解決上述兩種方式的不足出現(xiàn)的,是比較完美的一個。目前移動端的布局也都是用flexbox。 flexbox的缺點就是IE10開始支持,但是IE10的是-ms形式的。

四、表格布局

<!--表格布局-->
    <section class="layout table">
        <style>
            .layout.table .left-center-right {
                display: table;
                height: 150px;
                width: 100%;
            }
            .layout.table .left-center-right>div {
                display: table-cell;
            }
            .layout.table .left {
                width: 300px;
                background: red;
            }
            .layout.table .center {
                background: yellow;
            }
            .layout.table .right {
                width: 300px;
                background: blue;
            }
        </style>
        <h2>三欄布局</h2>
        <article class="left-center-right">
            <div class="left"></div>
            <div class="center">
                <h3>表格布局解決方案</h3>
                1.這是三欄布局的浮動解決方案; 2.這是三欄布局的浮動解決方案; 3.這是三欄布局的浮動解決方案; 4.這是三欄布局的浮動解決方案; 5.這是三欄布局的浮動解決方案; 6.這是三欄布局的浮動解決方案;
            </div>
            <div class="right"></div>
        </article>
    </section>

表格布局的兼容性很好(見下圖),在flex布局不兼容的時候,可以嘗試表格布局。當內(nèi)容溢出時會自動撐開父元素。

表格布局也是有缺陷:①無法設(shè)置欄邊距;②對seo不友好;③當其中一個單元格高度超出的時候,兩側(cè)的單元格也是會跟著一起變高的,然而有時候這并不是我們想要的效果。

css怎么實現(xiàn)三列布局

五、網(wǎng)格布局 

<!--網(wǎng)格布局-->
<section class="layout grid">
    <style>
        .layout.grid .left-center-right {
            display: grid;
            width: 100%;
            grid-template-columns: 300px auto 300px;
            grid-template-rows: 150px;//行高
        }
        .layout.grid .left {
            background: red;
        }
        .layout.grid .center {
            background: yellow;
        }
        .layout.grid .right {
            background: blue;
        }
    </style>
    <h2>三欄布局</h2>
    <article class="left-center-right">
        <div class="left"></div>
        <div class="center">
            <h3>網(wǎng)格布局解決方案</h3>
            1.這是三欄布局的浮動解決方案; 2.這是三欄布局的浮動解決方案; 3.這是三欄布局的浮動解決方案; 4.這是三欄布局的浮動解決方案; 5.這是三欄布局的浮動解決方案; 6.這是三欄布局的浮動解決方案;
        </div>
        <div class="right"></div>
    </article>
</section>

CSS Grid是創(chuàng)建網(wǎng)格布局最強大和最簡單的工具。就像表格一樣,網(wǎng)格布局可以讓Web設(shè)計師根據(jù)元素按列或行對齊排列,但他和表格不同,網(wǎng)格布局沒有內(nèi)容結(jié)構(gòu),從而使各種布局不可能與表格一樣。例如,一個網(wǎng)格布局中的子元素都可以定位自己的位置,這樣他們可以重疊和類似元素定位。

但網(wǎng)格布局的兼容性不好。IE10+上支持,而且也僅支持部分屬性。

六、總結(jié)

1、float布局是現(xiàn)在用的比較多的布局很多門戶網(wǎng)站目前使用這個布局方式,使用的時候只需要注意一定要清除浮動。

2、Position布局只是根據(jù)定位屬性去直接設(shè)置元素位置,個人感覺不太適合用做頁面布局

3、table布局使用起來方便,兼容性也不存在問題,不利于搜索引擎抓取信息

4、flex布局比較強大,但是還是存在IE上兼容性問題,只能支持到IE9以上

5、grid布局很強大,但是兼容性很差。

什么是css

css是一種用來表現(xiàn)HTML或XML等文件樣式的計算機語言,主要是用來設(shè)計網(wǎng)頁的樣式,使網(wǎng)頁更加美化。它也是一種定義樣式結(jié)構(gòu)如字體、顏色、位置等的語言,并且css樣式可以直接存儲于HTML網(wǎng)頁或者單獨的樣式單文件中,而樣式規(guī)則的優(yōu)先級由css根據(jù)這個層次結(jié)構(gòu)決定,從而實現(xiàn)級聯(lián)效果,發(fā)展至今,css不僅能裝飾網(wǎng)頁,也可以配合各種腳本對于網(wǎng)頁進行格式化。

以上是“css怎么實現(xiàn)三列布局”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:css怎么實現(xiàn)三列布局
文章路徑:http://bm7419.com/article40/pcocho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版云服務(wù)器、電子商務(wù)、Google、ChatGPT、服務(wù)器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化