Непрозрачность CSS и дочерние элементы
<style type="text/css">
div#foo {
background: #0000ff;
width: 200px;
height: 200px;
opacity: 0.30;
filter: alpha(opacity = 30);
}
div#foo>div {
color: black;
opacity:1;
filter: alpha(opacity = 100);
}
</style>
<div id="foo">
<div>Lorem</div>
<div>ipsum</div>
<div>dolor</div>
</div>
В приведенном выше примере, непрозрачность div#foo
наследуется дочерними элементами, в результате чего текст становится почти нечитаемым. Я полагаю, неправильно говорить, что он унаследован, непрозрачность применяется к родительскому div, и дети являются частью этого, поэтому попытка переопределить его для дочерних элементов не работает, потому что технически они непрозрачны.
Я обычно просто использую фоновое изображение alpha png в таких случаях, но сегодня мне интересно, есть ли лучше способ сделать фон div полупрозрачным, не затрагивая содержание.
3 ответов
вы можете использовать rgba ().
div#foo
{
background: rgba(0, 0, 255, 0.3);
}
чтобы заставить его работать в старых Internet Explorers использовать CSS ПИРОГ. Есть ограничения, но они обрабатываются обратно совместимым образом: значение RGB будет отображаться правильно, а непрозрачность будет игнорироваться.
Если вы используете непрозрачность, вам придется поместить их в отдельные DIV, а затем выстроить их вместе. Фоновый DIV будет иметь более низкую непрозрачность, а передний план DIV будет иметь ваш контент со 100% непрозрачностью.