Earlier today I asked Overlay a background-image with an rgba background-color. My goal is to have a div with a background-image, and when someone hovers the div, the background-image gets overlayed with an rgba color. In the answer, a solution with :after
was given:
#the-div {
background-image: url('some-url');
}
#the-div:hover:after {
content: ' ';
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
background-color: rgba(0,0,0,.5);
}
I now would like to have the same, but with a CSS transition: I'd like the background color to fade in. I tried adding transition: all 1s;
to the #the-div
CSS, but that didn't work. I also try to add it to #the-div:hover
and #the-div:after
, but that didn't work either.
Is there a pure CSS way to add a fading in overlay to a div with a background-image?
Allthough @Ana technique is also nice, and works fine, allow me to slightly alter my answer to the previous question, and add the transition in that code. http://jsfiddle.net/Pevara/N2U6B/2/
What I did is i defined the
:after
pseudo element on the default state of the div in stead of only on the hover state, but with a fully transparent background, and a transition on the background color. On hover of the div, I change the background color of the pseudo element to be less transparent. Thanks to the transition it fades in nicely.The technique is basicly the same as what @Ana did, but perhaps a bit more intuitive because I don't use the
background-color: inherit;
. Also if the div would becomes bigger then the background image, you would not get the 'double darkness' on the edges, as demonstrated here http://codepen.io/anon/pen/cjoHr versus here http://jsfiddle.net/Pevara/N2U6B/3/Yes, it is possible.
demo
What am I doing here?
What I am doing here is that I am setting a RGBa
background-color
on thediv
, behind itsbackground-image
and transitioning thisbackground-color
(its alpha) on:hover
. All this happens behind thebackground-image
. However, I am also usingbackground-color: inherit
on the pseudo-element, which means that, at any given moment, the pseudo-element, which is situated above its parentdiv
(and therefore above thebackground-image
of thediv
) is going to have the samebackground-color
(meaning that thebackground-color
of the pseudo-element is going to transition fromrgba(0,0,0,0)
torgba(0,0,0,.5)
on:hover
).Why do it this way?
The reason why I am not transitioning directly the
background-color
of the pseudo-element is that support for transitions on pseudo-elements is still not that good yet.Support for transitions on pseudo-elements
✓ Firefox supports transitions on pseudo-elements and has supported them for quite a while, let's get this out of the way first.
✗ Current versions of Safari and Opera don't support transitions on pseudo-elements.
Chrome supports transitions on pseudo-elements only starting from version 26.
IE10 supports them in a bit of a weird way, meaning that something like:
won't work, you have to specify the hover state on the element itself as well. Like this:
More info and examples about how you can transition various properties of pseudo-elements using this
inherit
technique: http://vimeo.com/51897358EDIT
Transitions directly on pseudo-elements are now supported in Opera since the switch to Blink and in Safari since 6.1.