• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Przezroczystość w CSS

+1 głos
80 wizyt
pytanie zadane 8 lipca 2021 w HTML i CSS przez Dawidziu Obywatel (1,760 p.)
Witam, czy jest możliwość ustawienia w CSS przezroczystości jakiegoś elementu z html na np. 50%, ale tak, aby elementy znajdujące się wewnątrz niego (div w divie) były widoczne w 100%.

2 odpowiedzi

+2 głosów
odpowiedź 8 lipca 2021 przez ::{}:: Gaduła (3,910 p.)
wybrane 8 lipca 2021 przez Dawidziu
 
Najlepsza
komentarz 8 lipca 2021 przez Dawidziu Obywatel (1,760 p.)
Dzięki, zadziałało
0 głosów
odpowiedź 8 lipca 2021 przez VBService VIP (144,010 p.)
edycja 8 lipca 2021 przez VBService

Chyba najprościej jest uzyskać ten efekt jak już podał @Oskarejro przez color alpha channel (rgba), ale przez pewien trick można też za pomocą opacity.  smiley

 

<div class="container">

  <div class="box">
    <div class="label-one">Lorem ipsum - box one<br>opacity</div>
    <div class="one"></div>
  </div>

  <div class="box two">
    <div class="label-two">Lorem ipsum - box two<br>color alpha channel</div>
  </div>

</div>
body, .container {
  margin: 0;
  padding: 0;
  border: 0;
  width: 100vw;
  height: 100vh;
  background-image: url(http://lorempixel.com/1200/1200/abstract);
}
.container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.box {
  position: relative;
  width: 250px;
  height: 150px;
  margin: 2em;
  border: 2px solid black;
  display: flex;
  justify-content: center;
  align-items: center;
  font: 900 1.2em/2em monospace;
}
.box .label-one, .label-two {
  width: 80%;
  border: 2px solid black;
  background-color: white;
  text-align: center;
}

.one {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: green;
  opacity: 0.5;
}
.box .label-one {
  position: relative;
  z-index: 2;
}

.two {
  background-color: rgba(255,0,0,0.5);
}

 

komentarz 8 lipca 2021 przez VBService VIP (144,010 p.)
edycja 8 lipca 2021 przez VBService

linear-gradient, można uzyskać efekt "połowy" elementu bardziej przezroczystego.  wink

 

<div class="container">

  <div class="box">
    <div class="label-one">Lorem ipsum - div one<br>opacity</div>
    <div class="one"></div>
  </div>

  <div class="box two">
    <div class="label-two">Lorem ipsum - div two<br>color alpha channel</div>
  </div>

  <div class="box three">
    <div class="label-two">Lorem ipsum - div three<br>color alpha channel<br>linear-gradient</div>
  </div>  

</div>
body, .container {
  margin: 0;
  padding: 0;
  border: 0;
  width: 100vw;
  height: 100vh;
  background-image: url(http://lorempixel.com/1200/1200/abstract);
}
.container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.box {
  position: relative;
  width: 300px;
  height: 150px;
  margin: 2em;
  border: 2px solid black;
  display: flex;
  justify-content: center;
  align-items: center;
  font: 900 1.2em/2em monospace;
}
.box .label-one, .label-two {
  width: 70%;
  border: 2px solid black;
  background-color: white;
  text-align: center;
}

.one {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: green;
  opacity: 0.5;
}
.box .label-one {
  position: relative;
  z-index: 2;
}

.two {
  background-color: rgba(255,0,0,0.5);
}

.three {
  background-image: linear-gradient(to right, rgba(0,0,0,0.9) 50%, transparent);
}

 

komentarz 8 lipca 2021 przez VBService VIP (144,010 p.)
edycja 8 lipca 2021 przez VBService

Można też przez zastosowanie np. ::before elementu html

  <div class="container">

    <div class="row">

      <div class="box">
        <div class="label-one">Lorem ipsum - div one<br>opacity</div>
        <div class="one"></div>
      </div>
      <div class="box two">
        <div class="label-two">Lorem ipsum - div two<br>color alpha channel</div>
      </div>

    </div>

    <div class="row">

      <div class="box three">
        <div class="label-three">Lorem ipsum - div three<br>color alpha channel<br>linear-gradient</div>
      </div>
      <div class="box four">
        <div class="label-three">Lorem ipsum - div four<br>opacity ::before</div>  
      </div>    

    </div>

  </div>
  body, .container {
    margin: 0;
    padding: 0;
    border: 0;
    width: 100vw;
    height: 100vh;
    background-image: url(http://lorempixel.com/1200/1200/abstract);
  }
  .container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
  }
  .box {
    position: relative;
    width: 300px;
    height: 150px;
    margin: 2em;
    border: 2px solid black;
    display: flex;
    justify-content: center;
    align-items: center;
    font: 900 1.2em/2em monospace;
  }
  .box .label-one, 
  .label-two, 
  .label-three {
    width: 70%;
    border: 2px solid black;
    background-color: white;
    text-align: center;
  }

  .one {
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: green;
    opacity: 0.5;
  }
  .box .label-one {
    position: relative;
    z-index: 2;
  }

  .two {
    background-color: rgba(0,255,255,0.25)
  }

  .three {
    background-image: linear-gradient(to right, rgba(0,0,0,0.9) 50%, transparent);
  }

  .four {
    position: relative;
    z-index: 0;
  }
  .four::before {
    content: '';
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 100%;
    background-color: yellow;
    opacity: 0.5;   
  }

 

Podobne pytania

0 głosów
2 odpowiedzi 585 wizyt
pytanie zadane 16 maja 2017 w HTML i CSS przez Al3x Użytkownik (870 p.)
0 głosów
1 odpowiedź 113 wizyt
pytanie zadane 13 września 2017 w HTML i CSS przez Radek Begej Użytkownik (580 p.)

86,448 zapytań

135,207 odpowiedzi

300,348 komentarzy

57,196 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...