gpt4 book ai didi

带显示的 CSS 动画关键帧无法淡入,但不会淡出

转载 作者:行者123 更新时间:2023-12-05 08:56:45 25 4
gpt4 key购买 nike

我有一个元素在开始时没有显示。当我向它添加一个类时,我希望它使用 CSS 淡入。

我找到了 this tutorial使用非常适合淡入的关键帧。但是如果我想以相同的方式淡出,元素会立即隐藏而没有动画。

基本上它看起来像这样:

.box {
display: none;
opacity: 0;
animation: FadeOut 1s ease-in-out;

&.active {
display: block;
opacity: 1;
animation: FadeIn 1s ease-in-out;
}
}

这是一个“有效”的例子: http://codepen.io/MickL/pen/NAopXN

最佳答案

尝试为 display:none 设置动画是问题的根源。为什么淡入起作用而淡出不起作用的困惑来自于同时使用 displayopacity

display 属性仅由是否应用 .active 决定;动画实际上并没有改变它,而 opacity 是按预期动画的。在淡入时,这意味着您会立即显示您的元素,然后从透明过渡到不透明。在淡出时,这意味着您会立即隐藏您的元素,然后在隐藏时从不透明过渡到透明。

有几种不同的方法可以解决这个问题,但这在某种程度上取决于上下文。例如,您可以将其保留为 block 元素并使用 height 属性使其折叠:

$('button').on('click', function(e) {
e.preventDefault();
$(this).siblings('.box').toggleClass('active');
})
@import "bourbon";
* {
box-sizing: border-box;
text-align: center;
}
button {
margin: 30px 0;
border: 1px solid #ccc;
text-align: center;
padding: 1em;
background: none;
box-shadow: none;
}
.box {
margin: 0 auto;
width: 80%;
height: 0;
display: block;
line-height: 100px;
background: #ccc;
border: 1px solid #444;
text-align: center;
opacity: 0;
animation: FadeOut 1s ease-in-out;
}
.box.active {
display: block;
height: initial;
opacity: 1;
animation: FadeIn 1s ease-in-out;
}
@keyframes FadeIn {
0% {
opacity: 0;
height: initial;
}
100% {
opacity: 1;
height: initial;
}
}
@keyframes FadeOut {
0% {
opacity: 1;
height: initial;
}
99% {
opacity: 0;
height: initial;
}
100% {
height: 0;
opacity: 0;
height: 0;
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="col">
<button class="toggle-good">Toggle display</button>
<p class="box good">I move nicely!</p>
<p>Extra paragraph to show collapse</p>
</div>

关于带显示的 CSS 动画关键帧无法淡入,但不会淡出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38934595/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com