真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

CSS中圣杯布局的三列式怎么用

這篇文章給大家介紹CSS的三列式怎么用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)公司一直秉承“誠信做人,踏實(shí)做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個(gè)客戶多一個(gè)朋友!專注中小微企業(yè)官網(wǎng)定制,成都網(wǎng)站制作、網(wǎng)站建設(shè),塑造企業(yè)網(wǎng)絡(luò)形象打造互聯(lián)網(wǎng)企業(yè)效應(yīng)。

DOM結(jié)構(gòu)如下:

XML/HTML Code復(fù)制內(nèi)容到剪貼板

  1.   
        
    
    
  

流程解說
接下來,讓我們一步一步地實(shí)現(xiàn)圣杯布局;

1、 首先分別浮動(dòng)main、sub、extra三列, 然后利用負(fù)外邊距把sub列和extra列定位到左右兩邊。這時(shí)的CSS代碼如下:

CSS Code復(fù)制內(nèi)容到剪貼板

  1. .main {   
     float: left;   
     width: 100%;   
     height: 300px;   
     background-color: rgba(255, 0, 0, .5);   
    }   
    .sub {   
     float: left;   
     width: 200px;   
     height: 300px;   
     margin-left: -100%;   
     background-color: rgba(0, 255, 0, .5);   
    }   
    .extra {   
     float: left;   
     width: 180px;   
     height: 300px;   
     margin-left: -180px;   
     background-color: rgba(0, 0, 255, .5);   
    }

2、 完成上步后,sub和extra列已經(jīng)到了正確的位置,但是sub和extra列卻覆蓋了main的兩邊,對于這個(gè)問題,圣杯布局的解決辦法是給容器container添加左、右內(nèi)邊距,從而讓main列定位到正確的位置。

CSS Code復(fù)制內(nèi)容到剪貼板

  1. .container {   
     padding-left: 210px;   
     padding-right: 190px;   
    }

3、 完成第二步后又出現(xiàn)了新問題:sub、extra列也受到容器左右內(nèi)邊距的影響位置發(fā)生了移動(dòng)。為了解決這個(gè)問題,圣杯布局使用相對定位使sub、extra列回到正確的位置。新添加代碼如下:

CSS Code復(fù)制內(nèi)容到剪貼板

  1. .sub {   
     position: relative;   
     left: -210px;   
    }   
    .extra {   
     position: relative;   
     rightright: -190px;   
    }

4、 當(dāng)瀏覽器縮小到一定程度時(shí),這個(gè)布局可能會(huì)被破壞,可以在body上添加min-width屬性解決。最終的圣杯布局CSS代碼如下:

CSS Code復(fù)制內(nèi)容到剪貼板

  1. body {   
     min-width: 600px; /* 2*sub + extra */  
    }   
    .container {   
     padding-left: 210px;   
     padding-right: 190px;   
    }   
    .main {   
     float: left;   
     width: 100%;   
     height: 300px;   
     background-color: rgba(255, 0, 0, .5);   
    }   
    .sub {   
     position: relative;   
     left: -210px;   
     float: left;   
     width: 200px;   
     height: 300px;   
     margin-left: -100%;   
     background-color: rgba(0, 255, 0, .5);   
    }   
    .extra {   
     position: relative;   
     rightright: -190px;   
     float: left;   
     width: 180px;   
     height: 300px;   
     margin-left: -180px;   
     background-color: rgba(0, 0, 255, .5);   
    }

點(diǎn)擊查看在線demo

完整實(shí)例
效果如下:
CSS中圣杯布局的三列式怎么用

CSS 和 DOM 代碼如下:

CSS Code復(fù)制內(nèi)容到剪貼板

  1.    
       
       
           
           
        圣杯布局   
      
           
        body {background-color: #ffffff; font-size:14px;}   
        #hd, #ft {padding:20px 3px; background-color: #cccccc; text-align: center;}   
        .bd-lft, .bd-rgt, .bd-3-lr, .bd-3-ll, .bd-3-rr {margin:10px 0; min-width:400px;}   
        .main {background-color: #03a9f4; color:#ffffff;}   
        .aside, .aside-1, .aside-2 {background-color: #00bcd4; color:#ffffff;}   
        p {margin:0; padding:20px; text-align: center;}   
           
           
        /* 左側(cè)欄固定寬度,右側(cè)自適應(yīng) */  
        .bd-lft {   
            zoom:1;   
            overflow:hidden;   
            padding-left:210px;   
        }   
        .bd-lft .aside {   
            float:left;   
            width:200px;   
            margin-left:-100%; /*= -100%*/  
      
            position:relative;   
            left:-210px; /* = -parantNode.paddingLeft */  
            _left: 0; /*IE6 hack*/  
        }   
        .bd-lft .main {   
            float:left;   
            width:100%;   
        }   
      
      
        /* 右側(cè)欄固定寬度,左側(cè)自適應(yīng) */  
        .bd-rgt {   
            zoom:1;   
            overflow:hidden;   
            padding-right:210px;   
        }   
        .bd-rgt .aside {   
            float:left;   
            width:200px;   
            margin-left:-200px; /* = -this.width */  
      
            position:relative;   
            rightright:-210px; /* = -parantNode.paddingRight */  
        }   
        .bd-rgt .main {   
            float:left;   
            width:100%;   
        }   
      
      
        /* 左中右 三欄自適應(yīng) */  
        .bd-3-lr {   
            zoom:1;   
            overflow:hidden;   
            padding-left:210px;   
            padding-right:210px;   
        }   
        .bd-3-lr .main {   
            float:left;   
            width:100%;   
        }   
        .bd-3-lr .aside-1 {   
            float: left;   
            width:200px;   
            margin-left: -100%;   
      
            position:relative;   
            left: -210px;   
            _left: 210px; /*IE6 hack*/  
        }   
        .bd-3-lr .aside-2 {   
            float: left;   
            width:200px;   
            margin-left: -200px;   
      
            position:relative;   
            rightright: -210px;   
        }   
      
        /* 都在左邊,右側(cè)自適應(yīng) */  
        .bd-3-ll {   
            zoom:1;   
            overflow:hidden;   
            padding-left:420px;   
        }   
        .bd-3-ll .main {   
            float:left;   
            width:100%;   
        }   
        .bd-3-ll .aside-1 {   
            float: left;   
            width:200px;   
            margin-left: -100%;   
      
            position:relative;   
            left: -420px;   
            _left: 0px; /*IE6 hack*/  
        }   
        .bd-3-ll .aside-2 {   
            float: left;   
            width:200px;   
            margin-left: -100%;   
      
            position:relative;   
            left: -210px;   
            _left: 210px; /*IE6 hack*/  
        }   
      
        /* 都在右邊,左側(cè)自適應(yīng) */  
        .bd-3-rr {   
            zoom:1;   
            overflow:hidden;   
            padding-right:420px;   
        }   
        .bd-3-rr .main {   
            float:left;   
            width:100%;   
        }   
        .bd-3-rr .aside-1 {   
            float: left;   
            width:200px;   
            margin-left: -200px;   
      
            position:relative;   
            rightright: -210px;   
        }   
        .bd-3-rr .aside-2 {   
            float: left;   
            width:200px;   
            margin-left: -200px;   
      
            position:relative;   
            rightright: -420px;   
        }   
      
      
           
      
       
       
      
        頭部   
           
           
               
                

    主內(nèi)容欄自適應(yīng)寬度

                                               

    側(cè)邊欄固定寬度

                                                               

    主內(nèi)容欄自適應(yīng)寬度

                                               

    側(cè)邊欄固定寬度

                                                               

    主內(nèi)容欄自適應(yīng)寬度

                                               

    側(cè)邊欄1固定寬度

                                               

    側(cè)邊欄2固定寬度

                                                               

    主內(nèi)容欄自適應(yīng)寬度

                                               

    側(cè)邊欄1固定寬度

                                               

    側(cè)邊欄2固定寬度

                                                               

    主內(nèi)容欄自適應(yīng)寬度

                                               

    側(cè)邊欄1固定寬度

                                               

    側(cè)邊欄2固定寬度

                                        底部          

圣杯布局的優(yōu)點(diǎn)總結(jié)如下:
1.使主要內(nèi)容列先加載。
2.允許任何列是最高的。
3.沒有額外的div。
4.需要的hack很少。

關(guān)于CSS的三列式怎么用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


本文標(biāo)題:CSS中圣杯布局的三列式怎么用
網(wǎng)站URL:http://weahome.cn/article/gejcsi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部