這篇文章主要為大家展示了“css中雙飛翼布局和圣杯布局的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“css中雙飛翼布局和圣杯布局的示例分析”這篇文章吧。
成都創(chuàng)新互聯(lián)公司主營(yíng)惠水網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,app軟件開(kāi)發(fā)公司,惠水h5小程序開(kāi)發(fā)搭建,惠水網(wǎng)站營(yíng)銷推廣歡迎惠水等地區(qū)企業(yè)咨詢
1、圣杯布局
浮動(dòng)、負(fù)邊距、相對(duì)定位、不添加額外標(biāo)簽
效果圖
DOM結(jié)構(gòu):
HeaderMainLeftRightFooter
樣式:
左中右部分樣式變化過(guò)程
1、中間部分需要根據(jù)瀏覽器寬度的變化而變化,所以要用100%,這里設(shè)*左中右向左浮動(dòng),因?yàn)橹虚g100%,左層和右層根本沒(méi)有位置上去
.left{ background: #E79F6D; width:150px; float:left; } .main{ background: #D6D6D6; width:100%; float:left; } .right{ background: #77BBDD; width:190px; float:left; }
2、把左層負(fù)margin150后,發(fā)現(xiàn)left上去了,因?yàn)樨?fù)到出窗口沒(méi)位置了,只能往上挪
.left{ background: #E79F6D; width:150px; float:left; margin-left:-150px; }
3、那么按第二步這個(gè)方法,可以得出它只要挪動(dòng)窗口寬度那么寬就能到最左邊了,利用負(fù)邊距,把左右欄定位
.left{ background: #E79F6D; width:150px; float:left; margin-left:-100%; } .right{ background: #77BBDD; width:190px; float:left; margin-left:-190px; }
4、然而問(wèn)題來(lái)了,中間被左右擋住了啊,只好給外層加padding了
.bd{ padding-left:150px; padding-right:190px; }
5、但是加了之后左右欄也縮進(jìn)來(lái)了,于是采用相對(duì)定位方法,各自相對(duì)于自己把自己挪出去,得到最終結(jié)果
.left{ background: #E79F6D; width:150px; float:left; margin-left:-100%; position: relative; left:-150px; } .right{ background: #77BBDD; width:190px; float:left; margin-left:-190px; position:relative; right:-190px; }
2、雙飛翼布局
在不增加額外標(biāo)簽的情況下,圣杯布局已經(jīng)非常完美,圣杯布局使用了相對(duì)定位,以后布局是有局限性的,而且寬度控制要改的地方也多,那么有沒(méi)其他方法更加簡(jiǎn)潔方便呢?
在淘寶UED探討下,增加多一個(gè)div就可以不用相對(duì)布局了,只用到了浮動(dòng)和負(fù)邊距,這就是我們所說(shuō)的雙飛翼布局。
DOM結(jié)構(gòu):main內(nèi)層增加了一個(gè)div
HeaderMain*LeftRightFooter
樣式:
去掉了左右欄的相對(duì)定位
去掉包裹層padding,以中間欄新增div的margin代替
body{ padding:0; margin:0 } .header,.footer{ width:100%; background:#666; height:30px;clear:both; } .bd{ /*padding-left:150px;*/ /*padding-right:190px;*/ } .left{ background: #E79F6D; width:150px; float:left; margin-left:-100%; /*position: relative;*/ /*left:-150px;*/ } .main{ background: #D6D6D6; width:100%; float:left; } .right{ background: #77BBDD; width:190px; float:left; margin-left:-190px; /*position:relative;*/ /*right:-190px;*/ } .inner{ margin-left:150px; margin-right:190px; }
3、雙飛翼布局和圣杯布局的區(qū)別
圣杯布局和雙飛翼布局解決問(wèn)題的方案在前一半是相同的,即:
中間欄寬度設(shè)置為100%
三欄全部float浮動(dòng)
左右兩欄加上負(fù)margin讓其跟中間欄div并排,以形成三欄布局。
不同在于解決中間欄div內(nèi)容不被遮擋問(wèn)題的思路不一樣。
圣杯布局
將三欄的外包裹層設(shè)置左右padding-left和padding-right
將左右兩個(gè)div用相對(duì)布局position: relative并分別配合right和left屬性,相對(duì)自身移動(dòng)以便不遮擋中間div
雙飛翼布局
中間div內(nèi)部創(chuàng)建子div用于放置內(nèi)容
在該子div里用margin-left和margin-right為左右兩欄div留出位置
多了1個(gè)div,少用4個(gè)css屬性(圣杯布局中間divp的adding-left和padding-right這2個(gè)屬性,加上左右兩個(gè)div用相對(duì)布局position: relative及對(duì)應(yīng)的right和left共4個(gè)屬性,一共6個(gè);而雙飛翼布局子div里用margin-left和margin-right共2個(gè)屬性,6-2=4)。
并且雙飛翼布局還有個(gè)好處,讓Main變成BFC元素了,屏幕寬度縮小Main也不會(huì)被擠下去,圣杯布局就會(huì)被擠下去。
以上是“css中雙飛翼布局和圣杯布局的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!