我意识到 CSS 过渡总是适用于已添加的类,而不是删除的类。但我想知道我的问题是否有一个优雅的解决方案。我有一组盒子,当悬停时,它们会变成一个圆圈。当按下按钮时,它们会增长/缩小。
我希望它们慢慢长大和缩小,但很快变成圆形/正方形。
此刻,它们慢慢地变大和缩小,很快变成圆形,又慢慢变回方形。这当然是因为盒子的 CSS 过渡持续时间设置为慢速,因此当圆形类被移除时,它们会恢复到原始速度。我提出了一个可行的解决方案(此处未包含),用于setTimeout
暂时添加“快速”类并将其删除。它确实解决了这个问题,但对我来说感觉非常难看。
你们有没有遇到过这个问题并想过更好的方法?或者这只是超出了 CSS 过渡的范围?
CSS:
.box {
background: red;
width: 100px;
height: 100px;
margin: 10px;
-webkit-transition: all 2s;
}
.big {
width: 300px;
}
.circle {
background: blue;
border-radius: 50px;
-webkit-transition-duration: .5s;
}
jQuery:
$('.box').on('mouseenter', function() {
$(this).addClass('circle');
})
$('.box').on('mouseleave', function() {
$(this).removeClass('circle');
})
$('.makeBig').on('click', function() {
$('.box').toggleClass('big');
})
HTML:
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<button class="makeBig">Grow!</button>
jsFiddle: