摘要:總結(jié)一下左邊固定,右邊自適應(yīng)的兩欄布局的七種方法。基本的樣式是,兩個(gè)相距左側(cè)寬基本的樣式是,兩個(gè)盒子相距左側(cè)盒子寬,右側(cè)盒子寬度自適應(yīng)。沒(méi)有清除浮動(dòng)的方法,若左側(cè)盒子高于右側(cè)盒子,就會(huì)超出父容器的高度。
總結(jié)一下左邊固定,右邊自適應(yīng)的兩欄布局的七種方法。其中有老生常談的float方法,BFC方法,也有CSS3的flex布局與grid布局。并非所有的布局都會(huì)在開(kāi)發(fā)中使用,但是其中也會(huì)涉及一些知識(shí)點(diǎn)。關(guān)于最終的效果,可以查看這里
常用的寬度自適應(yīng)的方法通常是利用了block水平的元素寬度能隨父容器調(diào)節(jié)的流動(dòng)特性。另外一種思路是利用CSS中的calc()方法來(lái)動(dòng)態(tài)設(shè)定寬度。還有一種思路是,利用CSS中的新型布局flex layout與grid layout。
首先創(chuàng)建基本的HTML布局和最基本的樣式。
左邊固定寬度,高度不固定 高度有可能會(huì)很小,也可能很大。這里的內(nèi)容可能比左側(cè)高,也可能比左側(cè)低。寬度需要自適應(yīng)。 基本的樣式是,兩個(gè)div相距20px, 左側(cè)div寬 120px
基本的樣式是,兩個(gè)盒子相距20px, 左側(cè)盒子寬 120px,右側(cè)盒子寬度自適應(yīng)。基本的CSS樣式如下:
.wrapper { padding: 15px 20px; border: 1px dashed #ff6c60; } .left { width: 120px; border: 5px solid #ffffd; } .right { margin-left: 20px; border: 5px solid #ffffd; }
下面的代碼都是基于這套基本代碼做覆蓋,通過(guò)給容器添加不同的類來(lái)實(shí)現(xiàn)效果。
雙inline-block方案.wrapper-inline-block { box-sizing: content-box; font-size: 0; // 消除空格的影響 } .wrapper-inline-block .left, .wrapper-inline-block .right { display: inline-block; vertical-align: top; // 頂端對(duì)齊 font-size: 14px; box-sizing: border-box; } .wrapper-inline-block .right { width: calc(100% - 140px); }
這種方法是通過(guò)width: calc(100% - 140px)來(lái)動(dòng)態(tài)計(jì)算右側(cè)盒子的寬度。需要知道右側(cè)盒子距離左邊的距離,以及左側(cè)盒子具體的寬度(content+padding+border),以此計(jì)算父容器寬度的100%需要減去的數(shù)值。同時(shí),還需要知道右側(cè)盒子的寬度是否包含border的寬度。
在這里,為了簡(jiǎn)單的計(jì)算右側(cè)盒子準(zhǔn)確的寬度,設(shè)置了子元素的box-sizing:border-box;以及父元素的box-sizing: content-box;。
同時(shí),作為兩個(gè)inline-block的盒子,必須設(shè)置vertical-align來(lái)使其頂端對(duì)齊。
另外,為了準(zhǔn)確地應(yīng)用計(jì)算出來(lái)的寬度,需要消除div之間的空格,需要通過(guò)設(shè)置父容器的font-size: 0;,或者用注釋消除html中的空格等方法。
缺點(diǎn):
需要知道左側(cè)盒子的寬度,兩個(gè)盒子的距離,還要設(shè)置各個(gè)元素的box-sizing
需要消除空格字符的影響
需要設(shè)置vertical-align: top滿足頂端對(duì)齊。
雙float方案.wrapper-double-float { overflow: auto; // 清除浮動(dòng) box-sizing: content-box; } .wrapper-double-float .left, .wrapper-double-float .right { float: left; box-sizing: border-box; } .wrapper-double-float .right { width: calc(100% - 140px); }
本方案和雙float方案原理相同,都是通過(guò)動(dòng)態(tài)計(jì)算寬度來(lái)實(shí)現(xiàn)自適應(yīng)。但是,由于浮動(dòng)的block元素在有空間的情況下會(huì)依次緊貼,排列在一行,所以無(wú)需設(shè)置display: inline-block;,自然也就少了頂端對(duì)齊,空格字符占空間等問(wèn)題。
A floated box is shifted to the left or right until its outer edge touches the containing block edge or the outer edge of another float.
不過(guò)由于應(yīng)用了浮動(dòng),父元素需要清除浮動(dòng)。
缺點(diǎn):
需要知道左側(cè)盒子的寬度,兩個(gè)盒子的距離,還要設(shè)置各個(gè)元素的box-sizing。
父元素需要清除浮動(dòng)。
float+margin-left方案.wrapper-float { overflow: hidden; // 清除浮動(dòng) } .wrapper-float .left { float: left; } .wrapper-float .right { margin-left: 150px; }
上面兩種方案都是利用了CSS的calc()函數(shù)來(lái)計(jì)算寬度值。下面兩種方案則是利用了block級(jí)別的元素盒子的寬度具有填滿父容器,并隨著父容器的寬度自適應(yīng)的流動(dòng)特性。
但是block級(jí)別的元素都是獨(dú)占一行的,所以要想辦法讓兩個(gè)block排列到一起。
我們知道,block級(jí)別的元素會(huì)認(rèn)為浮動(dòng)的元素不存在,但是inline級(jí)別的元素能識(shí)別到浮動(dòng)的元素。這樣,block級(jí)別的元素就可以和浮動(dòng)的元素同處一行了。
為了讓右側(cè)盒子和左側(cè)盒子保持距離,需要為左側(cè)盒子留出足夠的距離。這個(gè)距離的大小為左側(cè)盒子的寬度以及兩個(gè)盒子之間的距離之和。然后將該值設(shè)置為右側(cè)盒子的margin-left。
缺點(diǎn):
需要清除浮動(dòng)
需要計(jì)算右側(cè)盒子的margin-left
使用absolute+margin-left方法另外一種讓兩個(gè)block排列到一起的方法是對(duì)左側(cè)盒子使用position: absolute的絕對(duì)定位。這樣,右側(cè)盒子也能無(wú)視掉它。
.wrapper-absolute .left { position: absolute; } .wrapper-absolute .right { margin-left: 150px; }
缺點(diǎn):
使用了絕對(duì)定位,若是用在某個(gè)div中,需要更改父容器的position。
沒(méi)有清除浮動(dòng)的方法,若左側(cè)盒子高于右側(cè)盒子,就會(huì)超出父容器的高度。因此只能通過(guò)設(shè)置父容器的min-height來(lái)放置這種情況。
使用float+BFC方法上面的方法都需要通過(guò)左側(cè)盒子的寬度,計(jì)算某個(gè)值,下面三種方法都是不需要計(jì)算的。只需要設(shè)置兩個(gè)盒子之間的間隔。
.wrapper-float-bfc { overflow: auto; } .wrapper-float-bfc .left { float: left; margin-right: 20px; } .wrapper-float-bfc .right { margin-left: 0; overflow: auto; }
這個(gè)方案同樣是利用了左側(cè)浮動(dòng),但是右側(cè)盒子通過(guò)overflow: auto;形成了BFC,因此右側(cè)盒子不會(huì)與浮動(dòng)的元素重疊。
an element in the normal flow that establishes a new block formatting context (such as an element with "overflow" other than "visible") must not overlap the margin box of any floats in the same block formatting context as the element itself。
這種情況下,只需要為左側(cè)的浮動(dòng)盒子設(shè)置margin-right,就可以實(shí)現(xiàn)兩個(gè)盒子的距離了。而右側(cè)盒子是block級(jí)別的,所以寬度能實(shí)現(xiàn)自適應(yīng)。
缺點(diǎn):
父元素需要清除浮動(dòng)
flex方案.wrapper-flex { display: flex; align-items: flex-start; } .wrapper-flex .left { flex: 0 0 auto; } .wrapper-flex .right { flex: 1 1 auto; }
flex可以說(shuō)是最好的方案了,代碼少,使用簡(jiǎn)單。有朝一日,大家都改用現(xiàn)代瀏覽器,就可以使用了。
需要注意的是,flex容器的一個(gè)默認(rèn)屬性值:align-items: stretch;。這個(gè)屬性導(dǎo)致了列等高的效果。
為了讓兩個(gè)盒子高度自動(dòng),需要設(shè)置: align-items: flex-start;
又一個(gè)新型的布局方式。可以滿足需求,但這并不是它發(fā)揮用處的真正地方。
.wrapper-grid { display: grid; grid-template-columns: 120px 1fr; align-items: start; } .wrapper-grid .left, .wrapper-grid .right { box-sizing: border-box; } .wrapper-grid .left { grid-column: 1; } .wrapper-grid .right { grid-column: 2; }
注意:
grid布局也有列等高的默認(rèn)效果。需要設(shè)置: align-items: start;。
grid布局還有一個(gè)值得注意的小地方和flex不同:在使用margin-left的時(shí)候,grid布局默認(rèn)是box-sizing設(shè)置的盒寬度之間的位置。而flex則是使用兩個(gè)div的border或者padding外側(cè)之間的距離。
極限情況最后可以再看一下在父容器極限小的情況下,不同方案的表現(xiàn)。主要分成四種情況:
動(dòng)態(tài)計(jì)算寬度的情況
兩種方案: 雙inline-block方案和雙float方案。寬度極限小時(shí),右側(cè)的div寬度會(huì)非常小,由于遵循流動(dòng)布局,所以右側(cè)div會(huì)移動(dòng)到下一行。
動(dòng)態(tài)計(jì)算右側(cè)margin-left的情況
兩種方案: float+margin-left方案和absolute+margin-left方案。寬度極限小時(shí),由于右側(cè)的div忽略了文檔流中左側(cè)div的存在,所以其依舊會(huì)存在于這一行,并被隱藏。
float+BFC方案的情況
這種情況下,由于BFC與float的特殊關(guān)系,右側(cè)div在寬度減小到最小后,也會(huì)掉落到下一行。
flex和grid的情況
這種情況下,默認(rèn)兩種布局方式都不會(huì)放不下的div移動(dòng)到下一行。不過(guò) flex布局可以通過(guò) flex-flow: wrap;來(lái)設(shè)置多余的div移動(dòng)到下一行。 grid布局暫不支持。
如果感覺(jué)寫(xiě)的有問(wèn)題,懇請(qǐng)指出。
本文首發(fā)于我的博客
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/112429.html
摘要:高度模型淺識(shí)為的簡(jiǎn)寫(xiě),簡(jiǎn)稱為塊級(jí)格式化上下文,為瀏覽器渲染某一區(qū)域的機(jī)制,中只有和中還增加了和。并非所有的布局都會(huì)在開(kāi)發(fā)中使用,但是其中也會(huì)涉及一些知識(shí)點(diǎn)。然而在不同的純制作各種圖形純制作各種圖形多圖預(yù)警 一勞永逸的搞定 flex 布局 尋根溯源話布局 一切都始于這樣一個(gè)問(wèn)題:怎樣通過(guò) CSS 簡(jiǎn)單而優(yōu)雅的實(shí)現(xiàn)水平、垂直同時(shí)居中。記得剛開(kāi)始學(xué)習(xí) CSS 的時(shí)候,看到 float 屬性不...
摘要:目錄一大結(jié)構(gòu)上的導(dǎo)航欄和內(nèi)容區(qū)域兩欄布局博客園為例騰訊課堂個(gè)人中心頁(yè)慕課網(wǎng)個(gè)人中心頁(yè)個(gè)人中心頁(yè)二版的結(jié)構(gòu)三類似九宮格布局的兩列結(jié)構(gòu)四圖文兩列布局左圖右文字非垂直居中,左圖,右固定行數(shù)的文字,右側(cè)文字和左邊圖片垂直居中。目錄:一、大結(jié)構(gòu)上的導(dǎo)航欄和內(nèi)容區(qū)域兩欄布局1、博客園為例2、騰訊課堂個(gè)人中心頁(yè)3、慕課網(wǎng)個(gè)人中心頁(yè)4、github個(gè)人中心頁(yè)二、mini版的nav+cont結(jié)構(gòu)三、類似九宮格...
摘要:方案一方案二和方案的有點(diǎn)是兼容性好因?yàn)槎际潜容^老的解決方案了缺點(diǎn)是之后需要清除浮動(dòng)造成的影響定位的話就是絕對(duì)定位之后脫離文檔流了你要注意用包裹一下方案三是目前移動(dòng)端主流的方案的語(yǔ)法缺點(diǎn)就是以下不支持。 頁(yè)面布局 注意方案多樣性、各自原理、各自優(yōu)缺點(diǎn)、如果不定高呢、兼容性如何 三欄自適應(yīng)布局,左右兩側(cè)300px,中間寬度自適應(yīng) (1) 給出5種方案 方案一: float (左右浮動(dòng),中間...
摘要:方案一方案二和方案的有點(diǎn)是兼容性好因?yàn)槎际潜容^老的解決方案了缺點(diǎn)是之后需要清除浮動(dòng)造成的影響定位的話就是絕對(duì)定位之后脫離文檔流了你要注意用包裹一下方案三是目前移動(dòng)端主流的方案的語(yǔ)法缺點(diǎn)就是以下不支持。 頁(yè)面布局 注意方案多樣性、各自原理、各自優(yōu)缺點(diǎn)、如果不定高呢、兼容性如何 三欄自適應(yīng)布局,左右兩側(cè)300px,中間寬度自適應(yīng) (1) 給出5種方案 方案一: float (左右浮動(dòng),中間...
閱讀 3232·2021-11-24 09:39
閱讀 2955·2021-11-23 09:51
閱讀 904·2021-11-18 10:07
閱讀 3555·2021-10-11 10:57
閱讀 2766·2021-10-08 10:04
閱讀 3017·2021-09-26 10:11
閱讀 1063·2021-09-23 11:21
閱讀 2808·2019-08-29 17:28