I'm trying to transition an element nicely from being visually hidden and back but it's not working too well.
CodePen: http://codepen.io/gutterboy/pen/VemYrL
The effect I am looking for is something similar to jQuery's slidedown effect... like this: http://codepen.io/gutterboy/pen/adBGar
Edit: This question is NOT about how to transition from a display: none;
state, but how to transition from the code below specifically as this is a more user-friendly way to hide content for accessibility purposes.
HTML:
<div class="foo visuallyhidden">Lorem ipsum dolor sit amet, consectetur adipiscing elit. An tu me de L. Dat enim intervalla et relaxat. Zenonis est, inquam, hoc Stoici. At certe gravius. Quid, de quo nulla dissensio est? Duo Reges: constructio interrete. Nulla erit controversia.</div>
<div class="button">
<button id="show">Show Box</button>
</div>
CSS:
.foo {
margin: 0px auto;
margin-top: 30px;
border: 1px solid gray;
padding: 15px;
max-width: 500px;
transition: 0.3s ease-in-out;
}
.button {
text-align: center;
}
button {
position: absolute;
top: 300px;
}
.visuallyhidden {
position: absolute;
overflow: hidden;
clip: rect(0 0 0 0);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
transition: 0.3s ease-in-out;
}
JS:
$('#show').on('click', function(e) {
$('.foo').toggleClass('visuallyhidden');
});