為什麼 CSS 浮動不會改變後續 Div 的寬度?
在元素上使用 float:left 屬性時,這是預期的後續元素會將其自身定位到浮動元素的右側,而不是其下方。但是,在某些情況下,後續元素可能會繼續跨越整個寬度。
出現這種情況是因為 CSS 中浮動元素的基本行為。當元素浮動時,它會從文件的正常流程中刪除,並實際上變得像圖像一樣。浮動元素後面的內容在其周圍流動,從而創建換行符。
但是,包含塊的寬度(決定了後續元素可用的水平空間)不受浮動元素的影響。浮動元素的邊距框(包括任何內容)保留在包含區塊中,因此後續元素仍必須與其右邊緣對齊。
W3C 提供的範例說明了此行為:
[浮動元素與段落中的後續元素重疊的圖像]
如圖所示,浮動元素佔據包含塊中的空間,後續內容環繞它。縮短浮動右側的行框以容納它。
解決方案:建立新的區塊格式上下文
防止後續元素與浮動重疊元素,CSS提供了利用overflow屬性的解決方案。將溢出屬性設為「visible」以外的其他屬性(例如「hidden」或「scroll」)會為元素建立一個新的區塊格式化上下文。
在這個新的區塊格式化上下文中,浮動元素的邊距框受到限制,禁止它與同一上下文中的任何其他浮動重疊。因此,後續元素現在可以將自身對齊到浮動元素的右側:
[溢位範例:應用隱藏]
.yellow {
overflow: hidden;
}
在處理圍繞浮動元素流動的內容足夠長以在浮動後正常繼續的元素時,此行為變得特別相關。預設限制重疊將阻止內容在浮動元素下方繼續。
以上是為什麼浮動元素不影響後續div的寬度?的詳細內容。更多資訊請關注PHP中文網其他相關文章!