我正在构建一个基于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;
}
元素不会淡入。就像浏览器跳过动画并立即触发最终结果一样。
答案 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;
}
答案 1 :(得分:0)
无法为显示属性设置动画。 none
和block
之间根本没有渐进的阶段。
在你的情况下,你可以通过使用巨大的负顶部位置“隐藏”元素,并在目标事件上将其恢复为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>