亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-09-15 11:46:02 來源:億速云 閱讀:106 作者:柒染 欄目:web開發

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

DOM結構如下:

XML/HTML Code復制內容到剪貼板

  1. <div class="container">  
        <div class="main"></div>  
     <div class="sub"></div>  
     <div class="extra"></div>  
    </div>

流程解說
接下來,讓我們一步一步地實現圣杯布局;

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

CSS Code復制內容到剪貼板

  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列已經到了正確的位置,但是sub和extra列卻覆蓋了main的兩邊,對于這個問題,圣杯布局的解決辦法是給容器container添加左、右內邊距,從而讓main列定位到正確的位置。

CSS Code復制內容到剪貼板

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

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

CSS Code復制內容到剪貼板

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

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

CSS Code復制內容到剪貼板

  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);   
    }

點擊查看在線demo

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

CSS 和 DOM 代碼如下:

CSS Code復制內容到剪貼板

  1. <!DOCTYPE html>   
    <html>   
    <head>   
        <meta charset="utf-8">   
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">   
        <title>圣杯布局</title>   
      
        <style type="text/css">   
        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;}   
           
           
        /* 左側欄固定寬度,右側自適應 */  
        .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%;   
        }   
      
      
        /* 右側欄固定寬度,左側自適應 */  
        .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%;   
        }   
      
      
        /* 左中右 三欄自適應 */  
        .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;   
        }   
      
        /* 都在左邊,右側自適應 */  
        .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*/  
        }   
      
        /* 都在右邊,左側自適應 */  
        .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;   
        }   
      
      
        </style>   
      
    </head>   
    <body>   
      
        <div id="hd">頭部</div>   
           
        <div class="bd-lft">   
            <div class="main">   
                <p>主內容欄自適應寬度</p>   
            </div>   
      
            <div class="aside">   
                <p>側邊欄固定寬度</p>   
            </div>   
        </div>   
      
        <div class="bd-rgt">   
            <div class="main">   
                <p>主內容欄自適應寬度</p>   
            </div>   
      
            <div class="aside">   
                <p>側邊欄固定寬度</p>   
            </div>   
        </div>   
      
        <div class="bd-3-lr">   
            <div class="main">   
                <p>主內容欄自適應寬度</p>   
            </div>   
      
            <div class="aside-1">   
                <p>側邊欄1固定寬度</p>   
            </div>   
      
            <div class="aside-2">   
                <p>側邊欄2固定寬度</p>   
            </div>   
        </div>   
      
        <div class="bd-3-ll">   
            <div class="main">   
                <p>主內容欄自適應寬度</p>   
            </div>   
      
            <div class="aside-1">   
                <p>側邊欄1固定寬度</p>   
            </div>   
      
            <div class="aside-2">   
                <p>側邊欄2固定寬度</p>   
            </div>   
        </div>   
      
        <div class="bd-3-rr">   
            <div class="main">   
                <p>主內容欄自適應寬度</p>   
            </div>   
      
            <div class="aside-1">   
                <p>側邊欄1固定寬度</p>   
            </div>   
      
            <div class="aside-2">   
                <p>側邊欄2固定寬度</p>   
            </div>   
        </div>   
           
        <div id="ft">底部</div>   
      
    </body>   
    </html>

圣杯布局的優點總結如下:
1.使主要內容列先加載。
2.允許任何列是最高的。
3.沒有額外的div。
4.需要的hack很少。

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和平区| 古蔺县| 阜康市| 灵丘县| 上饶市| 闸北区| 梅河口市| 肥乡县| 合阳县| 松溪县| 两当县| 会同县| 繁峙县| 浏阳市| 尖扎县| 保定市| 汝阳县| 广安市| 和静县| 昌图县| 绥棱县| 永顺县| 昭平县| 汕头市| 大埔县| 株洲县| 泰和县| 南丰县| 苍南县| 凉城县| 南开区| 定边县| 晋州市| 莎车县| 佛学| 都昌县| 稻城县| 同心县| 志丹县| 茌平县| 城步|