国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

CSS Float nine rules

bingo / 2684人閱讀

注:本文是對(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 rules

CSSfloat才開(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 100
100 x 100
100 x 100
65 x 100
65 x 100
100 x 100
100 x 100
400 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:left
100 x 250 float:right
400 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

1
2
3
400 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 Rule8

原文:A floating box must be placed as high as possible.

譯文:一個(gè)浮動(dòng)盒子應(yīng)該放的盡可能的高

CSS Float Rule9

原文: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 100

P2 : 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

相關(guān)文章

  • CSS Float nine rules

    注:本文是對(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)的博客文章,加...

    Nino 評(píng)論0 收藏0
  • 【generator101】 - yield from

    摘要:我們可以看一下的可見(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...

    xiaodao 評(píng)論0 收藏0
  • CSS外掛:Sass 之規(guī)則(Rules)和指令(Directives)

    摘要:根據(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...

    honhon 評(píng)論0 收藏0
  • leetcode423. Reconstruct Original Digits from Engl

    摘要:如對(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...

    kviccn 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<