首頁 >web前端 >css教學 >為什麼「overflow:hidden」會導致帶有浮動元素的容器的高度意外增長?

為什麼「overflow:hidden」會導致帶有浮動元素的容器的高度意外增長?

Linda Hamilton
Linda Hamilton原創
2024-12-02 12:59:10598瀏覽

Why Does `overflow: hidden` Cause Unexpected Height Growth in Containers with Floated Elements?

溢出:浮動元素的隱藏和意外高度增長

問題:
溢出時:隱藏是應用於包含浮動元素的外部元素,為什麼外部元素的高度會意外增長以包含浮動元素他們?

答案:
高度的意外增長是因為溢位:隱藏創建了一個新的區塊格式化上下文(BFC)。 BFC 根(包含不可見的溢出元素)會擴展其高度以容納浮動(如果它們沒有指定的高度)。

根據CSS 規範,阻止格式化上下文根「拉伸以包含如果它們本身沒有指定高度,則它們會按高度浮動,預設為自動。」此高度增加也適用於底部邊距邊緣超過BFC 根的底部內容邊緣的浮動後代。

與清除浮動的區別
請注意,此行為與浮動清除不同,後者僅當應用清除屬性並且有前面的浮動要清除時發生。在這種情況下:

  • 在 BFC 根外部的元素上使用clear: Both 會清除浮動,但不會導致外部元素拉伸。
  • 將零高度元素放置為清除:都位於 BFC 根內部,確保外部元素向下拉伸以容納浮動元素的底部邊緣(稱為“clearfix”)。

以上是為什麼「overflow:hidden」會導致帶有浮動元素的容器的高度意外增長?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn