在CSS 中,如果子元素(#inner) 超出其父元素(#outer) 的彎曲邊框,則會出現父母和孩子之間的行為似乎有差異。本文探討了發生這種情況的原因,並提供了強制子元素符合父元素彎曲邊界的解決方案。
重疊子元素問題
當父元素( #outer) 使用border-radius 具有彎曲邊框,並且子元素(#inner) 延伸到這些邊框之外,它可以創建重疊。這是因為預設情況下,子元素不會受到約束以尊重其父元素的彎曲邊框。
溢位:隱藏解
根據 CSS 規範,裁剪背景和其他效果到邊界,就像溢位一樣,也應該剪裁到曲線。因此,在父元素(#outer)上設定溢位:隱藏應該可以解決此問題。但是,此解決方案可能不適用於 Firefox 3.6 及更低版本等較舊的瀏覽器。
Mozilla 特定的 Hack
對於 Firefox 3.6 及更低版本,需要特定的 hack。透過將曲線分配給各個邊框,可以強制子元素 (#inner) 符合父元素的彎曲邊框。例如:
<code class="css">#inner { border-top-right-radius: 10px; -moz-border-radius-topright: 10px; -webkit-border-top-right-radius: 10px; border-top-left-radius: 10px; -moz-border-radius-topleft: 10px; -webkit-border-top-left-radius: 10px; }</code>
此 hack 可確保子元素 (#inner) 尊重其父元素 (#outer) 的彎曲邊框,即使在較舊的瀏覽器中也是如此。
更新的解決方案
在Firefox 4 及更高版本等較新的瀏覽器中,溢出:隱藏和邊框半徑的組合足以強制子元素服從其父元素的彎曲邊框。因此,更新的解決方案是:
<code class="css">#outer { overflow: hidden; } #inner { -moz-border-radius: 10px 10px 0 0; }</code>
這確保了將子元素剪切到其父元素的彎曲邊框的跨瀏覽器相容性。
以上是CSS中如何讓子元素符合父元素的曲線邊框?的詳細內容。更多資訊請關注PHP中文網其他相關文章!