Animate:CSS3中目标事件的目标元素

时间:2015-02-07 12:32:00

标签: css css3 animation css-transitions

我正在构建一个基于CSS3选择器:target的灯箱,它根据网址中的哈希值选择一个元素。我想在:target事件上设置目标元素的动画,但这似乎不起作用。

假设我们在按下#banana which的链接时显示div #banana

#banana {display: none;}
#banana:target {display: block;}

这很好用。但是当试图为元素设置动画时,这不起作用。见this fiddle

div#banana {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
    opacity: 0;
    transition: opacity 5s linear 1s;
}

div#banana:target {
    display: block;
    opacity: 1;
}

元素不会淡入。就像浏览器跳过动画并立即触发最终结果一样。

2 个答案:

答案 0 :(得分:0)

问题是您正在更改display属性。 display属性无法转换,因为您无法真正动画元素从无任何内容转换为块。

display属性可以完全省略。但是,您需要提供元素visibility: hidden,以便不会阻止点击链接,然后将其转换为visibility: visible

div#banana {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
    opacity: 0;
    transition: opacity 5s linear 1s;
    visibility: hidden;
}

div#banana:target {
    opacity: 1;
    visibility: visible;
}

Updated fiddle

答案 1 :(得分:0)

无法为显示属性设置动画。 noneblock之间根本没有渐进的阶段。

在你的情况下,你可以通过使用巨大的负顶部位置“隐藏”元素,并在目标事件上将其恢复为0。实际转换将通过更改不透明度来处理。

div#banana {
    position: fixed;
    left: 0;
    top: -1000px;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
    opacity: 0;
    transition: opacity 1s linear;
}

div#banana:target {
    top: 0;
    opacity: 1;
}
<div id="banana">
    <a href="#">close</a>
</div>
<a href="#banana">Do you want a banana? Click me!</a>