CSS布局之圣杯布局與雙飛翼布局

按照我的理解,其實圣杯布局跟雙飛翼布局的實現(xiàn),目的都是左右兩欄固定寬度,中間部分自適應(yīng)。
圣杯布局
實現(xiàn)原理
html代碼中,middle部分首先要放在container的最前部分,然后是left,right
1.將三者都設(shè)置 float:left, position:relative (因為相對定位后面會用到)
2.middle設(shè)置 width:100% 占滿一行
3.此時middle占滿一行,所以要把left拉到middle所在行的最左邊,使用 margin-left:-100%
4.這時left拉回到middle所在行的最左邊,但會覆蓋middle內(nèi)容的左端,要把middle內(nèi)容拉出來,所以在外圍container加上 padding:0 210px
5.middle內(nèi)容拉出來了,但left也跟著出來了,所以要還原,就對left使用相對定位 left:-210px
6.同理,right要拉到middle所在行的最右邊,使用 margin-left:-210px,right:-210px
實現(xiàn)代碼
JavaScript Code復(fù)制內(nèi)容到剪貼板
- <!DOCTYPE HTML>
- <html lang="en-US">
- <head>
- <meta charset="UTF-8">
- <title>圣杯布局</title>
- <style type="text/css">
- body {
- text-align: center;;
- }
- #demo {
- margin: auto;
- }
- #header, #footer {
- height: 50px;
- background-color: #aaa;
- }
- #container {
- overflow: hidden;
- margin: 10px 0;
- padding:0 210px;
- }
- #left {
- background-color: red;
- float:left;
- position:relative;
- left:-210px;
- width:200px;
- margin-left:-100%;
- }
- #right {
- background-color: green;
- width: 200px;
- margin-left: -200px;
- float: left;
- right: -210px;
- position: relative;
- }
- #middle {
- background-color: blue;
- float:left;
- width:100%;
- }
- </style>
- </head>
- <body>
- <div id="demo">
- <header id="header">頭部</header>
- <div id="container">
- <div id="middle">
- middle<br>主內(nèi)容區(qū)域
- </div>
- <div id="left">
- left<br>左側(cè)邊欄區(qū)域
- </div>
- <div id="right">
- right<br>右側(cè)邊欄區(qū)域
- </div>
- </div>
- <footer id="footer">底部</footer>
- </div>
- </body>
- </html>
雙飛翼布局
實現(xiàn)原理
html代碼中,middle部分首先要放在container的最前部分,然后是left,right
1.將三者都設(shè)置 float:left
2.middle設(shè)置 width:100% 占滿一行
3.此時middle占滿一行,所以要把left拉到middle所在行的最左邊,使用 margin-left:-100%,同理right使用 margin-left:-200px
4.此時middle的內(nèi)容被覆蓋,要把middle的內(nèi)容拉出來,除了使用外圍container的padding,還可以考慮使用margin,給middle增加一個內(nèi)層div -- middle_content, 然后設(shè)置 margin:0 210px
實現(xiàn)代碼
JavaScript Code復(fù)制內(nèi)容到剪貼板
- <!DOCTYPE HTML>
- <html lang="en-US">
- <head>
- <meta charset="UTF-8">
- <title>雙飛翼布局</title>
- <style type="text/css">
- body {
- text-align: center;;
- }
- #header, #footer {
- height: 50px;
- background-color: #aaa;
- }
- #container {
- overflow: hidden;
- margin: 10px 0;
- }
- #left {
- background-color: red;
- float:left;
- width:200px;
- margin-left: -100%;
- }
- #right {
- background-color: green;
- width: 200px;
- float: left;
- margin-left: -200px;
- }
- #middle {
- float: left;
- width: 100%;
- }
- #middle_content {
- background-color: blue;
- margin: 0 210px;
- }
- </style>
- </head>
- <body>
- <div id="demo">
- <header id="header">頭部</header>
- <div id="container">
- <div id="middle">
- <div id="middle_content">
- middle_content<br>主內(nèi)容區(qū)域
- </div>
- </div>
- <div id="left">
- left<br>左側(cè)邊欄區(qū)域
- </div>
- <div id="right">
- right<br>右側(cè)邊欄區(qū)域
- </div>
- </div>
- <footer id="footer">底部</footer>
- </div>
- </body>
- </html>
關(guān)于CSS布局之圣杯布局與雙飛翼布局 的相關(guān)知識就給大家介紹這么多,希望對大家有所幫助!
相關(guān)文章
- 這篇文章主要介紹了淺談css雙飛翼布局和圣杯布局,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-18
- 圣杯布局效果優(yōu)美且對瀏覽器兼容性要求非常低,是一種非常給力的三列式頁面布局方案,接下來就來看看對CSS的三列式"圣杯布局"方案完全解析:2016-06-02
- 圣杯布局和雙飛翼布局是前端工程師需要日常掌握的重要布局方式。圣杯布局和雙飛翼布局是很多大廠必考的內(nèi)容,本文就詳細(xì)介紹一下這兩個布局有什么區(qū)別,感興趣的可以了解一2021-05-13