這篇文章給大家介紹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)容到剪貼板
流程解說
接下來,讓我們一步一步地實(shí)現(xiàn)圣杯布局;
1、 首先分別浮動(dòng)main、sub、extra三列, 然后利用負(fù)外邊距把sub列和extra列定位到左右兩邊。這時(shí)的CSS代碼如下:
CSS Code復(fù)制內(nèi)容到剪貼板
.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)容到剪貼板
.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)容到剪貼板
.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)容到剪貼板
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 和 DOM 代碼如下:
CSS Code復(fù)制內(nèi)容到剪貼板
圣杯布局 頭部主內(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ò),可以把它分享出去讓更多的人看到。