2014-11-21 58 views
2

我有<div>裏面的文字沒有border屬性。div內的文字行爲

<div id="main"> 
    <div id="second"></div> 
    <p>TEXT</p> 
</div> 

CSS

#second { 
    height: 100px; 
    width: 100px; 
    background:red; 
    float:left; 
} 

#main { 
    width: 200px; 
    height: 200px; 
} 

我的文字對齊如與其他分區上顯示在this example

當我添加CSS邊框屬性DIV,pharagraph已申請保證金 - see here

它爲什麼會發生?

+0

這是由於摺疊邊緣。如果沒有'border',則應用於'p'的默認'margin'溢出'div'。在邊界處,'margin'包含在'div'中。 – 2014-11-21 11:52:48

回答

2

這是意想不到的行爲來自只使用float:left;一格。如果你使用float也是,那麼你不會得到不同的行爲。

Check this demo:打開/關閉邊框。

spec

一個浮動框被移動到左側或右側,直到其外緣接觸包含塊邊緣或另一浮體的外邊緣。如果存在線框,浮動框的外部頂部與當前線框的頂部對齊。

如果浮子沒有足夠的水平空間,它將向下移動,直到它適合或不再有浮子存在。