注:本文是對(duì)眾多博客的學(xué)習(xí)和總結(jié),可能存在理解錯(cuò)誤。請(qǐng)帶著懷疑的眼光,同時(shí)如果有錯(cuò)誤希望能指出。
如果你喜歡我的文章,可以關(guān)注我的私人博客:http://blog-qeesung.rhcloud.com/
入門前端也算是有三個(gè)月之久了,發(fā)現(xiàn)Float這個(gè)屬性一直都很迷惑,只是知道一些簡(jiǎn)單的浮動(dòng)規(guī)則,并沒(méi)有深入去學(xué)習(xí),一旦遇到一點(diǎn)復(fù)雜的浮動(dòng)場(chǎng)景,自己也就懵了。
于是在網(wǎng)上找了數(shù)篇關(guān)于浮動(dòng)的博客文章,加上自己理解,在這里總結(jié)一下。
w3 css float nine rulesCSS的float才開(kāi)始學(xué)習(xí)的時(shí)候總是感覺(jué)沒(méi)有任何的規(guī)律可言,總是有許多想不明白的地方,"為什么這個(gè)div塊要在這個(gè)div塊的下方?","為什么這個(gè)浮動(dòng)元素會(huì)是這樣對(duì)齊?"。
其實(shí)Float是有規(guī)則可以依據(jù)的,Float一共有九個(gè)規(guī)則來(lái)控制浮動(dòng)元素的行為:
The left outer edge of a left-floating box may not be to the left of the left edge of its containing block. An analogous rule holds for right-floating elements.
If the current box is left-floating, and there are any left-floating boxes generated by elements earlier in the source document, then for each such earlier box, either the left outer edge of the current box must be to the right of the right outer edge of the earlier box, or its top must be lower than the bottom of the earlier box. Analogous rules hold for right-floating boxes.
The right outer edge of a left-floating box may not be to the right of the left outer edge of any right-floating box that is next to it. Analogous rules hold for right-floating elements.
A floating box"s outer top may not be higher than the top of its containing block. When the float occurs between two collapsing margins, the float is positioned as if it had an otherwise empty anonymous block parent taking part in the flow. The position of such a parent is defined by the rules in the section on margin collapsing.
The outer top of a floating box may not be higher than the outer top of any block or floated box generated by an element earlier in the source document.
The outer top of an element"s floating box may not be higher than the top of any line-box containing a box generated by an element earlier in the source document.
A left-floating box that has another left-floating box to its left may not have its right outer edge to the right of its containing block"s right edge. (Loosely: a left float may not stick out at the right edge, unless it is already as far to the left as possible.) An analogous rule holds for right-floating elements.
A floating box must be placed as high as possible.
A left-floating box must be put as far to the left as possible, a right-floating box as far to the right as possible. A higher position is preferred over one that is further to the left/right.
上述內(nèi)容摘錄于此處,咋一看挺復(fù)雜,其實(shí)真的挺復(fù)雜的,對(duì)于博主我這種英語(yǔ)渣來(lái)說(shuō),是挺難理解的,如果文中有翻譯或者理解不對(duì)的地方,希望大家指正。
CSS Float Rule1原文:The left outer edge of a left-floating box may not be to the left of the left edge of its containing block. An analogous rule holds for right-floating elements.
譯文:左浮動(dòng)的盒子的左邊界不會(huì)超出容器的左邊界,右浮動(dòng)同理.
以左浮動(dòng)為例:
html
css
body{ background-color:yellow; } #outer-div{ height:200px; width:200px; background-color:red; } #inner-div{ height:100px; width:100px; background-color:blue; float:left; }
顯示效果
100x100的藍(lán)色盒子為左浮動(dòng)元素,200x200的紅色盒子為藍(lán)色盒子的容器,可見(jiàn)藍(lán)盒子的左邊界沒(méi)有超出紅色盒子的左邊界。
CSS Float Rule2原文:If the current box is left-floating, and there are any left-floating boxes generated by elements earlier in the source document, then for each such earlier box, either the left outer edge of the current box must be to the right of the right outer edge of the earlier box, or its top must be lower than the bottom of the earlier box. Analogous rules hold for right-floating boxes.
譯文:如果盒子是左浮動(dòng)的,那么在html文檔中晚出現(xiàn)的左浮動(dòng)盒子只允許出現(xiàn)在先出現(xiàn)的左浮動(dòng)盒子的右邊或者晚出現(xiàn)的左浮動(dòng)盒子的頂部必須在早出現(xiàn)左浮動(dòng)盒子的底部之下。右浮動(dòng)同理.
以左浮動(dòng)為例:
html
100 x 100100 x 100100 x 10065 x 10065 x 100100 x 100100 x 100400 x 500
css
#outer-div{ height:400px; width:500px; background-color:red; } #inner-div{ height:100px; width:100px; background-color:blue; float:left; margin:10px; } #inner-div1{ height:65px; width:100px; background-color:pink; float:left; margin:10px; } body{ background-color:yellow }
顯示效果:
這里需要解釋的有幾個(gè)地方:
方塊五為何不另起一行,放在方塊一下面,而是放在方塊四的下面? 這里我們將會(huì)在Rule8和Rule9解釋
方塊六和方塊1之間為何空著那么寬的空間? 這是因?yàn)榉綁K五早出現(xiàn)在方塊六之前,所以方塊六的頂部不會(huì)超出方塊五的底部。
CSS Float Rule3原文:The right outer edge of a left-floating box may not be to the right of the left outer edge of any right-floating box that is next to it. Analogous rules hold for right-floating elements.
譯文:左浮動(dòng)盒子的右外邊緣可能不在其旁邊的任何右浮動(dòng)框的左外邊緣的右邊,右浮動(dòng)同理.
html
150 x 270 float:left100 x 250 float:right400 x 500
css
div{ margin:5px; } #outer-div{ height:400px; width:500px; background-color:red; } #float-left { height:150px; width:270px; float:left; background-color:blue; } #float-right{ height:100px; width:250px; float:right; background-color:blue; } body{ background-color:yellow }
顯示效果:
左浮動(dòng)盒子的寬度(270)+有浮動(dòng)盒子的寬度(250)> 容器的寬度(500),所以右浮動(dòng)盒子并沒(méi)有和左浮動(dòng)盒子并列,而是在左浮動(dòng)盒子的下方。
CSS Float Rule4原文:A floating box’s outer top may not be higher than the top of its containing block. When the float occurs between two collapsing margins, the float is positioned as if it had an otherwise empty anonymous block parent taking part in the flow. The position of such a parent is defined by the rules in the section on margin collapsing.
譯文:浮動(dòng)盒子的頂部不能超出容器的頂部邊界
這個(gè)就不用解釋了
CSS Float Rule5原文:The outer top of a floating box may not be higher than the outer top of any block or floated box generated by an element earlier in the source document.
譯文:浮動(dòng)盒子的頂部不會(huì)超出在html文檔中早出現(xiàn)的的塊級(jí)元素(block)或者是浮動(dòng)元素的頂部
html
123400 x 500
css
div{ margin:5px; } #outer-div{ height:400px; width:500px; background-color:red; } #float-left { height:100px; width:100px; float:left; background-color:lightblue; } #float-right{ height:100px; width:200px; float:right; background-color:lightyellow; } body{ background-color:yellow }
顯示效果:
如果將紅色容器的礦都縮短為,使之單行之內(nèi)不能夠容下三個(gè)浮動(dòng)元素,那么哪一個(gè)盒子會(huì)被擠到下一行呢?1?2?3?
我們來(lái)試著將紅色容器盒子的寬度縮減為400px
#outer-div{ height:400px; width:400px; background-color:red; }
我們將會(huì)得到下面顯示效果
可見(jiàn)盒子三被擠到了下一行,這是因?yàn)楹凶佣膆tml文件中比盒子三早出現(xiàn),所以盒子二不能低于盒子三。于是就將盒子三下沉。
CSS Float Rule6原文:The outer top of an element’s floating box may not be higher than the top of any line-box containing a box generated by an element earlier in the source document.
譯文:浮動(dòng)盒子的頂部不會(huì)超出在html文檔中早出現(xiàn)的包含盒子的line-box元素頂部
html
Purus ut faucibus pulvinar elementum integer enim neque, volutpat ac tincidunt vitae, semper quis lectus nulla at volutpat diam ut. Dui vivamus arcu felis, bibendum ut tristique et, egestas quis ipsum suspendisse ultrices gravida dictum fusce ut placerat orci nulla!100 x 100
css
div{ margin:5px; } #outer-div{ height:400px; width:500px; background-color:red; } #float-left { height:100px; width:100px; float:left; background-color:lightblue; } body{ background-color:yellow }
顯示效果:
在浮動(dòng)元素之前是一行行內(nèi)元素,所以浮動(dòng)盒子就沒(méi)有超過(guò)文本的最后一行的頂部。可能這里不太清晰,我們將文本換成圖片再看一下。
html
100 x 100
顯示效果
為什么浮動(dòng)元素不浮動(dòng)上去把一個(gè)圖片元素?cái)D下來(lái)呢?如果浮動(dòng)元素向上浮動(dòng)將一個(gè)圖片元素?cái)D到第二行,那么現(xiàn)在浮動(dòng)元素就高于比它早出現(xiàn)的圖片元素。就違反了規(guī)則
這里我們?cè)囍鴮⒓t色盒子容器寬度縮小,使之一行之內(nèi)容不下四個(gè)圖片。
css
#outer-div{ height:400px; width:400px; background-color:red; }
那么圖片將會(huì)折行,如下所示
行內(nèi)元素圖片四就環(huán)繞浮動(dòng)元素,但是浮動(dòng)元素并沒(méi)有超出行內(nèi)元素的。
CSS Float Rule7原文:A left-floating box that has another left-floating box to its left may not have its right outer edge to the right of its containing block’s right edge. (Loosely: a left float may not stick out at the right edge, unless it is already as far to the left as possible.) An analogous rule holds for right-floating elements.
譯文:一個(gè)左浮動(dòng)元素右邊的另一個(gè)左浮動(dòng)元素的右邊界不會(huì)超出容器的右邊界,右浮動(dòng)同理
這個(gè)也很好理解,就是如果一行之內(nèi)要放第二個(gè)浮動(dòng)元素,如果放不下了,那就換行。這個(gè)就不詳細(xì)解釋啦
CSS Float Rule8CSS Float Rule9原文:A floating box must be placed as high as possible.
譯文:一個(gè)浮動(dòng)盒子應(yīng)該放的盡可能的高
原文:A left-floating box must be put as far to the left as possible, a right-floating box as far to the right as possible. A higher position is preferred over one that is further to the left/right.
譯文:一個(gè)左浮動(dòng)元素應(yīng)該放的盡可能的靠左,右浮動(dòng)元素應(yīng)該被放的盡可能的靠右。當(dāng)元素既可以放置"最高"又可以"最右"的時(shí)候,優(yōu)先考慮"最高"。
上面的兩個(gè)規(guī)則要連起來(lái)一起看,這里我們就借鑒一下規(guī)則二中的例子
為什么盒子五不直接放在盒子一下面,這是因?yàn)楫?dāng)一個(gè)元素既可以放的最左(最右)和最高的時(shí)候,優(yōu)先選擇最高,所以這里就放在了盒子四的下面。
finally最后說(shuō)兩句,浮動(dòng)元素其實(shí)對(duì)在它出現(xiàn)之前的元素影響不大,但是由于浮動(dòng)是使元素脫離了文檔流,那么在浮動(dòng)元素之后出現(xiàn)的元素:
塊元素:直接無(wú)視浮動(dòng)元素,該怎么顯示就怎么顯示,并且會(huì)被浮動(dòng)元素覆蓋。
行內(nèi)元素:行內(nèi)元素會(huì)環(huán)繞在浮動(dòng)元素周圍。
下面我們就來(lái)一個(gè)簡(jiǎn)單的例子:
html
P1 : Augue neque, gravida in fermentum et, sollicitudin ac orci phasellus egestas tellus rutrum tellus pellentesque eu tincidunt tortor aliquam nulla?
100 x 100P2 : At lectus urna duis convallis convallis tellus, id interdum velit laoreet id donec ultrices tincidunt arcu, non sodales neque sodales ut etiam. Feugiat vivamus at augue eget arcu dictum varius?
css
div{ margin:5px; } #outer-div{ height:400px; width:500px; background-color:red; } #float-left { height:100px; width:100px; float:left; background-color:lightblue; } body{ background-color:yellow }
顯示效果
這里因?yàn)?b>p1是block元素,直接卡住了浮動(dòng)元素,然后p2這個(gè)block元素直接忽視了浮動(dòng)元素的存在,然后排版在浮動(dòng)元素的下方,但是p2的中的文本是inline元素,于是就圍繞浮動(dòng)元素排布。
參考文章W3 float-rules
Everything You Never Knew About CSS Floats
The CSS Float Rules
CSS浮動(dòng)float詳解
回歸CSS標(biāo)準(zhǔn)之Float
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/111350.html
注:本文是對(duì)眾多博客的學(xué)習(xí)和總結(jié),可能存在理解錯(cuò)誤。請(qǐng)帶著懷疑的眼光,同時(shí)如果有錯(cuò)誤希望能指出。如果你喜歡我的文章,可以關(guān)注我的私人博客:http://blog-qeesung.rhcloud.com/ 入門前端也算是有三個(gè)月之久了,發(fā)現(xiàn)Float這個(gè)屬性一直都很迷惑,只是知道一些簡(jiǎn)單的浮動(dòng)規(guī)則,并沒(méi)有深入去學(xué)習(xí),一旦遇到一點(diǎn)復(fù)雜的浮動(dòng)場(chǎng)景,自己也就懵了。 于是在網(wǎng)上找了數(shù)篇關(guān)于浮動(dòng)的博客文章,加...
摘要:我們可以看一下的可見(jiàn)是由內(nèi)部支持的,其實(shí)現(xiàn)原理上就避免了棧進(jìn)棧出的消耗,直接由最內(nèi)層的返回值。另外可以實(shí)現(xiàn)外部直接向最內(nèi)層的傳遞值,比如這段代碼的輸出是這樣傳值的方式,在用循環(huán)重新的模式下是無(wú)法實(shí)現(xiàn)的。這也就是必須使用,而不能使用的原因。 在python 3.3里,generator新增了一個(gè)語(yǔ)法 yield from 這個(gè)yield from的作用是什么?看下面兩段對(duì)比的代碼: d...
摘要:根據(jù)文件名引入。這和指令非常相似,只要后面的條件為就會(huì)執(zhí)行。被編譯為循環(huán)指令的形式,是個(gè)變量名,是一個(gè)表達(dá)式,他將返回一個(gè)列表值。被編譯為學(xué)完了回過(guò)頭來(lái)整理也真是麻煩,算是總結(jié)吧。 前戲:下面這些玩意還是比較實(shí)用的,好像是進(jìn)階Sass必備的,以后寫(xiě)起 CSS 要溜得飛起啊! 規(guī)則(Rules) 1. @import Sass 擴(kuò)展了 CSS 的 @import 規(guī)則,讓它能夠引入 SC...
摘要:如對(duì)應(yīng)的英文表達(dá)為并繼續(xù)亂序成。要求輸入亂序的英文表達(dá)式,找出其中包含的所有的數(shù)字,并按照從小到大輸出。思路和代碼首先將數(shù)字和英文表示列出來(lái)粗略一看,我們知道有許多字母只在一個(gè)英文數(shù)字中出現(xiàn),比如只出現(xiàn)在中。 題目要求 Given a non-empty string containing an out-of-order English representation of digits...
閱讀 1563·2021-11-25 09:43
閱讀 2349·2019-08-30 15:55
閱讀 1472·2019-08-30 13:08
閱讀 2685·2019-08-29 10:59
閱讀 825·2019-08-29 10:54
閱讀 1596·2019-08-26 18:26
閱讀 2555·2019-08-26 13:44
閱讀 2661·2019-08-23 18:36