CSS - Размещение <divs> поверх прозрачных <div>

0

Есть ли способ сделать контент/изображения не прозрачными, если внутри <div> есть прозрачность?

Здесь HTML:

    <div id="main-button-wrapper" class="left">

        <div id="button-bg-layer" class="box-bg-layer corners"></div>

        <div class="buttons-bg-overlay box-bg-overlay corners">

            <img alt="Test" src="http://www.schroff.co.uk/railway/src/symbol_test.gif" />

        </div>

    </div>

CSS:

#main-button-wrapper {
    height: 319px;
    margin-left: 22px;
    position: relative;
    width: 321px;
}

#button-bg-layer {
    position: absolute;
    right: 0;
    height: 319px;
    width: 321px;
}

.buttons-bg-overlay {
    position: relative;
    right: 0;
    margin: 11px;
    height: 66px;
    width: 299px;
    text-align: center;
    padding-top: 26px;
}

#buttons-wrapper {
    position: relative;
    width: 299px;
    height: 297px;
    z-index: 3;
    margin: 22px;
}

/* Background Layers */

.box-bg-layer {
    background-color: #010101;
    z-index: 1;
    zoom: 1;
    filter: alpha(opacity=40);
    opacity: 0.4;   
}

.box-bg-overlay {
    background-color: #010101;
    z-index: 2;
    zoom: 1;
    filter: alpha(opacity=40);
    opacity: 0.4;   
}

Я пробовал поставить z-index: 4; на изображении. Единственный другой способ, которым я могу думать, - установить фон div как абсолютное позиционирование, а затем позиционировать контент вне div, но должен быть более простой способ?

Любая помощь приветствуется!

См. JSFiddle:

http://jsfiddle.net/Sa8jw/

Теги:

2 ответа

1
Лучший ответ

Вот вам скрипка js для вашей помощи :-)

FIDDLE

и измененный код. где непрозрачность добавляется в псевдокласс после

    #main-button-wrapper {
    height: 319px;
    margin-left: 22px;
    position: relative;
    width: 321px;
}

#button-bg-layer {
    position: absolute;
    right: 0;
    height: 319px;
    width: 321px;
}

.buttons-bg-overlay {
    position: relative;
    right: 0;
    margin: 11px;
    height: 66px;
    width: 299px;
    text-align: center;
    padding-top: 26px;
}

#buttons-wrapper {
    position: relative;
    width: 299px;
    height: 297px;
    z-index: 3;
    margin: 22px;
}

/* Background Layers */
.box-bg-layer{
background-color: #010101;
    z-index: 1;
zoom: 1;}
.box-bg-layer : after{

    filter: alpha(opacity=40);
    opacity: 0.4;   
}
.box-bg-overlay {   background-color: red;
    z-index: 2;
    zoom: 1;
}
.box-bg-overlay :after{
    filter: alpha(opacity=40);
    opacity: 0.4;   
}
5

Вместо использования opacity используйте rgba где a обозначает alpha. Это сделает дочерние элементы не прозрачными...

background-color: rgba(0,0,0,.5); /* RGBA for #010101 will be rgba(1,1,1,.4) */

Где .4 для a эквивалентно opacity: 0.4

демонстрация

  • 0
    Да, непрозрачность наследуется всеми детьми, в то время как цвет фона rgba не будет.
  • 0
    Не работает, я думаю, есть поближе
Показать ещё 8 комментариев

Ещё вопросы

Сообщество Overcoder
Наверх
Меню