Czy jest możliwe, używając tylko CSS, aby background
element był półprzezroczysty, ale jego zawartość (tekst i obrazy) jest nieprzezroczysta?
Chciałbym to osiągnąć bez tekstu i tła jako dwóch osobnych elementów.
Podczas próby:
p {
position: absolute;
background-color: green;
filter: alpha(opacity=60);
opacity: 0.6;
}
span {
color: white;
filter: alpha(opacity=100);
opacity: 1;
}
<p>
<span>Hello world</span>
</p>
Wygląda na to, że elementy potomne podlegają nieprzezroczystości swoich rodziców, więc opacity:1
jest względne w stosunku do opacity:0.6
rodzica.
p
krycie było,.6
aspan
krycie było,.5
wówczas prawdziwa krycie tekstu w zakresie byłoby0.3
.opacity:.5
dla elementu nadrzędnego iopacity:2
elementu podrzędnego?opacity:2;
jest to nieprawidłowy CSS . Wartośćopacity
właściwości musi zawierać się w przedziale obejmującym [0,1].Odpowiedzi:
Użyj półprzezroczystego obrazu PNG lub użyj CSS 3:
Oto artykuł z css3.info, Opacity, RGBA i kompromisu (2007-06-03).
źródło
background-color: rgba(#000, .5);
W Firefoksie 3 i Safari 3 możesz używać RGBA jak wspomniany Georg Schölly .
Mało znaną sztuczką jest to, że można jej używać również w Internet Explorerze za pomocą filtra gradientu.
Pierwsza liczba szesnastkowa określa wartość alfa koloru.
Pełne rozwiązanie dla wszystkich przeglądarek:
Wynika to z przezroczystości tła CSS bez wpływu na elementy potomne, poprzez RGBa i filtry .
Zrzuty ekranu dowód wyników:
Dzieje się tak przy użyciu następującego kodu:
źródło
To najlepsze rozwiązanie, jakie mogłem wymyślić, NIE używając CSS 3. I o ile dobrze widzę, działa świetnie w Firefox, Chrome i Internet Explorer.
Umieść pojemnik
div
i dwoje dziecidiv
na tym samym poziomie, jeden dla zawartości, jeden dla tła. I używając CSS, automatycznie dopasuj rozmiar tła do zawartości i umieść tło faktycznie z tyłu za pomocą indeksu Z.źródło
:after
i uniknąć dodatkowych znaczników?W przypadku prostego półprzezroczystego koloru tła powyższe rozwiązania (obrazy CSS3 lub bg) są najlepszymi opcjami. Jeśli jednak chcesz zrobić coś bardziej wymyślnego (np. Animację, wiele środowisk itp.) Lub jeśli nie chcesz polegać na CSS3, możesz wypróbować „technikę okienkową”:
Technika działa przy użyciu dwóch „warstw” wewnątrz zewnętrznego elementu szyby:
position: relative
Na panelu jest ważna; informuje tylną warstwę, aby dopasowała się do rozmiaru szyby. (Jeśli potrzebujesz, aby<p>
znacznik był bezwzględny, zmień panel z a<p>
na a<span>
i zawiń wszystko w<p>
znaczniku absolutnie ustawionym ).Główną zaletą tej techniki w porównaniu do podobnych wymienionych powyżej jest to, że okienko nie musi mieć określonego rozmiaru; zgodnie z powyższym kodem zmieści się na całej szerokości (normalny układ elementów blokowych) i tylko tak wysoko, jak treść. Zewnętrzny element panelu może być dowolnie dopasowany, pod warunkiem, że jest prostokątny (tzn. Blok wstawiany będzie działał; zwykły wstawka nie będzie).
Daje też dużą swobodę w tle; możesz dowolnie umieszczać cokolwiek w tylnym elemencie i nie wpływać na przepływ treści (jeśli chcesz mieć wiele pełnowymiarowych podwarstw, upewnij się, że mają również pozycję: bezwzględną, szerokość / wysokość: 100%, oraz góra / dół / lewo / prawo: auto).
Jedną z odmian umożliwiającą regulację wstawki w tle (przez górny / dolny / lewy / prawy) i / lub przypinanie tła (poprzez usunięcie jednej pary lewej / prawej lub górnej / dolnej) jest użycie następującego CSS:
Jak napisano, działa to w Firefox, Safari, Chrome, IE8 + i Opera, chociaż IE7 i IE6 wymagają dodatkowego CSS i wyrażeń, IIRC, a kiedy ostatnio sprawdzałem, druga odmiana CSS nie działa w Operze.
Na co należy zwrócić uwagę:
<div>
s zamiast<span>
s, aby uprościć swój CSS.Pełniejsze demo, pokazujące elastyczność tej techniki poprzez użycie jej w parze z
display: inline-block
, oraz z obydwomaauto
i konkretnymiwidth
s /min-height
s:A oto prezentacja na żywo szeroko stosowanej techniki:
źródło
width:
iheight:
właściwości mają wspólną linię, ponieważ są one tego samego typu konstrukcją i lepiej rozumiane jako kształt dwuwymiarowy, a nie para wiązań 1-wymiarowych. Co więcej, niektóre wiersze są spakowane w znaczną ilość, ponieważ powtarzające się treści nie są aż tak ważne, aby się pochwalić.Lepiej jest użyć półprzezroczystego
.png
.Po prostu otwórz Photoshop , utwórz
2x2
obraz pikselowy ( wybranie1x1
może spowodować błąd przeglądarki Internet Explorer! ), Wypełnij go zielonym kolorem i ustaw krycie w „zakładce Warstwy” na 60%. Następnie zapisz go i ustaw jako tło:Oczywiście działa świetnie, z wyjątkiem uroczego programu Internet Explorer 6 . Dostępne są lepsze poprawki, ale oto szybki hack:
źródło
Istnieje sposób na zminimalizowanie znaczników: użyj pseudoelementu jako tła i możesz ustawić krycie na nim bez wpływu na główny element i jego elementy podrzędne:
PRÓBNY
Wynik:
Odpowiedni kod:
Obsługa przeglądarki to Internet Explorer 8 i nowsze wersje.
źródło
Najłatwiejszą metodą byłoby użycie półprzezroczystego obrazu PNG w tle .
W razie potrzeby możesz użyć JavaScript, aby działał w Internet Explorerze 6 .
Korzystam z metody opisanej w przezroczystych plikach PNG w programie Internet Explorer 6 .
Poza tym możesz go sfałszować za pomocą dwóch bocznych elementów rodzeństwa - zrób jeden półprzezroczysty , a następnie absolutnie umieść drugi nad górą .
źródło
Ta metoda pozwala mieć obraz w tle, a nie tylko jednolity kolor, i może być używana do przezroczystości innych atrybutów, takich jak ramki. Nie są wymagane przezroczyste obrazy PNG.
Użyj
:before
(lub:after
) w CSS i nadaj im wartość krycia, aby pozostawić element z oryginalnym kryciem. W ten sposób możesz użyć: przed, aby zrobić sztuczny element i nadać mu przezroczyste tło (lub obramowania), które chcesz, i przesunąć go za zawartość, z którą chcesz zachować nieprzejrzystośćz-index
.Przykład ( skrzypce ) (zauważ, że
DIV
klasa withdad
ma tylko zapewnić kontekst i kontrast z kolorami, ten dodatkowy element w rzeczywistości nie jest potrzebny, a czerwony prostokąt jest przesunięty nieco w dół i w prawo, aby pozostawić widoczne tło z tyłufancyBg
elementu):z tym CSS:
W tym przypadku
.fancyBg:before
ma właściwości CSS, które chcesz mieć z przezroczystością (w tym przykładzie czerwone tło, ale może to być obraz lub obramowanie). Jest pozycjonowany jako absolutny, aby przesunąć go w tył.fancyBg
(użyj wartości zero lub cokolwiek bardziej odpowiedniego dla twoich potrzeb).źródło
Problem polega na tym, że tekst w twoim przykładzie ma pełne krycie. Ma pełną nieprzezroczystość wewnątrz
p
znacznika, alep
znacznik jest tylko półprzezroczysty.Możesz dodać półprzezroczysty obraz tła PNG zamiast realizować go w CSS lub podzielić tekst i podzielić na dwa elementy i przesunąć tekst nad ramką (na przykład margines ujemny).
W przeciwnym razie nie będzie to możliwe.
Tak jak wspomniał Chris: jeśli używasz pliku PNG z przezroczystością, musisz użyć obejścia JavaScript, aby działało w nieznośnym Internet Explorerze ...
źródło
Prawie wszystkie te odpowiedzi zakładają, że projektant chce mieć jednolity kolor tła. Jeśli projektant naprawdę chce zdjęcia jako tła, jedynym prawdziwym rozwiązaniem jest w tej chwili JavaScript, taki jak wspomniana gdzie indziej wtyczka jQuery Transify .
To, co musimy zrobić, to dołączyć do dyskusji grupy roboczej CSS i sprawić, by dali nam atrybut krycia tła! Powinno działać ręka w rękę z funkcją wielu środowisk.
źródło
Oto jak to robię (może nie być optymalne, ale działa):
Utwórz ten
div
, który ma być półprzezroczysty. Nadaj mu klasę / identyfikator. Pozostaw to puste i zamknij. Daj mu ustawioną wysokość i szerokość (powiedzmy 300 na 300 pikseli). Daj mu krycie 0,5 lub cokolwiek chcesz i kolor tła.Następnie, bezpośrednio poniżej tego div, utwórz kolejny div z inną klasą / id. Utwórz w nim akapit, w którym umieścisz swój tekst. Podaj
div
pozycję: względną i górną:-295px
(to 295 pikseli ujemnych ). Nadaj mu indeks z 2 dla dobrej miary i upewnij się, że jego krycie wynosi 1. Nadaj styl akapitowi, jak chcesz, ale upewnij się, że wymiary są mniejsze niż pierwszego,div
aby się nie przelał.Otóż to. Oto kod:
Działa to w przeglądarce Safari 2.x, ale nie wiem o Internet Explorerze.
źródło
:before
lub:after
Oto wtyczka jQuery, która obsłuży wszystko za Ciebie, Transify ( Transify - wtyczka jQuery do łatwego zastosowania przezroczystości / krycia na tle elementu ).
Od czasu do czasu napotykałem ten problem, więc postanowiłem napisać coś, co znacznie ułatwi życie. Skrypt ma mniej niż 2 KB i wymaga tylko jednego wiersza kodu, aby go uruchomić, a także obsłuży animację krycia tła, jeśli chcesz.
źródło
Jakiś czas temu pisałem o tym w Cross Browser Background Transparency With CSS .
Dziwacznie Internet Explorer 6 pozwoli ci uczynić tło przezroczystym, a tekst na wierzchu całkowicie nieprzejrzystym. W przypadku innych przeglądarek sugeruję użycie przezroczystego pliku PNG.
źródło
Krycie tła, ale nie tekst ma kilka pomysłów. Użyj półprzezroczystego obrazu lub nałóż dodatkowy element.
źródło
Jeśli jesteś facetem z Photoshopa , możesz także użyć:
Lub:
źródło
Aby tło elementu było półprzezroczyste, ale jego zawartość (tekst i obrazy) były nieprzezroczyste, musisz napisać kod CSS dla tego obrazu i dodać jeden atrybut
opacity
o minimalnej wartości.Na przykład,
// Im mniejsza wartość, tym bardziej będzie przezroczysta, lub wartość mniej będzie przezroczysta.
źródło
CSS 3 ma proste rozwiązanie twojego problemu. Posługiwać się:
Tutaj
rgba
oznacza wartości czerwony, zielony, niebieski i alfa. Wartość zieloną uzyskuje się z powodu 255, a połowę przezroczystości uzyskuje się przy wartości 0,5 alfa.źródło
Jeśli używasz Mniej , możesz użyć
fade(color, 30%)
.źródło
kolor tła: rgba (255, 0, 0, 0,5); jak wspomniano powyżej, najlepsza odpowiedź jest po prostu postawiona. Używanie CSS 3, nawet w 2013 roku, nie jest proste, ponieważ poziom obsługi z różnych przeglądarek zmienia się z każdą iteracją.
Chociaż
background-color
jest obsługiwany przez wszystkie główne przeglądarki (nie nowe w CSS 3) [1], przezroczystość alfa może być trudna, szczególnie w przypadku Internet Explorera wcześniejszego niż wersja 9 i koloru obramowania w Safari przed wersją 5.1. [2]Korzystanie z czegoś takiego jak Compass lub SASS może naprawdę pomóc w produkcji i kompatybilności między platformami.
[1] W3Schools: Właściwość koloru tła CSS
[2] Blog Normana: Lista kontrolna obsługi przeglądarki CSS3 (październik 2012 r.)
źródło
Możesz rozwiązać ten problem w programie Internet Explorer 8 przez (ab) przy użyciu składni gradientu. Format kolorów to ARGB. Jeśli korzystasz z preprocesora Sass , możesz konwertować kolory za pomocą wbudowanej funkcji „ie-hex-str ()”.
źródło
Można użyć czystego CSS 3 :
rgba(red, green, blue, alpha)
, gdziealpha
jest poziom przejrzystości chcesz. Nie ma potrzeby korzystania z JavaScript ani jQuery.Oto przykład:
źródło
http://jsfiddle.net/x2ukko7u/ ?
źródło
Możesz to zrobić za
rgba color code
pomocą CSS, takiego jak ten przykład podany poniżej.źródło
Łatwiejszym rozwiązaniem jest nałożenie nakładki na obraz na ten sam div. To niewłaściwe użycie tego narzędzia. Ale działa jak urok, aby wykonać tę nakładkę za pomocą CSS.
Użyj wbudowanego cienia w ten sposób:
To wszystko :)
źródło
Możesz użyć RGBA
(red, green, blue, alpha)
w CSS . Coś takiego:Więc po prostu robienie czegoś takiego będzie działać w twoim przypadku:
źródło
Z mojego punktu widzenia najlepszym sposobem na użycie koloru tła z kryciem jest jak poniżej. Jeśli użyjemy tego, nie stracimy krycia dla innych elementów, takich jak kolor testowy, obramowanie itp.
Użyj koloru tła z kryciem
źródło
Zwykle używam tej klasy do mojej pracy. To całkiem nieźle.
źródło
Działa dla mnie, gdy korzystałem z formatu,
#AARRGGBB
więc ten, który dla mnie działał, był#1C00ff00
. Spróbuj, bo widziałem, że działa dla niektórych, a nie dla kogoś innego. Używam go w CSS.źródło
Możesz użyć wartości krycia dołączonej do wartości szesnastkowej:
W tym przykładzie
aa
jest nieprzezroczystość. Nieprzezroczystość00
oznacza przezroczystość iff
oznacza jednolity kolor.Krycie jest opcjonalne, więc możesz zawsze używać wartości szesnastkowej:
Możesz także użyć starego sposobu z
rgba()
:I
background
stenografia, jeśli chcesz się upewnić, że tło nie ma innych stylów, takich jak obrazy lub gradienty:Ze specyfikacji Mozilli ( https://developer.mozilla.org/en-US/docs/Web/CSS/background-color ):
źródło
Możesz użyć koloru RGB z nieprzezroczystością, jak kod koloru w RGB (63, 245, 0) i dodać nieprzezroczystość (jak 63, 245, 0, 0,5), a także zamienić RGB na RGBA.
A
ma być używany do krycia.źródło