У меня есть div внутри другого div. #outer
и #inner
. #outer
имеет изогнутые границы и белый фон. #inner
не имеет изогнутых границ и зеленого фона. #inner
выходит за пределы изогнутых границ #outer
. Есть ли способ остановить это?
#outer {
display: block; float: right; margin: 0; width: 200px;
background-color: white; overflow: hidden;
-moz-border-radius: 10px;
-khtml-border-radius: 10px;
-webkit-border-radius: 10px;
border-radius: 10px;
}
#inner { background-color: #209400; height: 10px; border-top: none; }
<div id="outer">
<div id="inner"></div>
<!-- other stuff needs a white background -->
<!-- bottom corners needs a white background -->
</div>
Независимо от того, как я стараюсь, это все равно накладывается. Как я могу заставить #inner
повиноваться и заполнять границы #outer
?
1020 * редактировать *
Следующий хак послужил цели на данный момент. Но вопрос стоит (может быть, CSS3 и авторам веб-браузера): Почему дочерние элементы не подчиняются изогнутым границам своих родителей и есть ли в любом случае их заставить?
Хак, чтобы обойти это для моих нужд, вы можете назначить кривые для отдельных границ. Поэтому для моих целей я просто назначил кривую двум верхним внутренним элементам.
#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;
}