我想做一个简单的动画与jQuery在火狐浏览器中工作绝对好,但它在Chrome和边缘闪烁,这里是一个jsfiddle,这里是代码:隐藏和显示元素与jQuery在Chrome和边缘闪烁
HTML
<div id="boxes-wrapper">
<div class="box"></div><div class="box"></div><div class="box"></div>
</div>
CSS
.box {
width: 150px;
height: 150px;
display: inline-block;
margin: 0;
padding: 0;
vertical-align: top;
}
.box:first-child {
background: pink;
}
.box:nth-child(2) {
background: skyblue;
}
.box:nth-child(3) {
background: gold;
}
.box.hover {
position: relative;
z-index: 20;
}
html, body {
position: relative;
width: 100%;
height: 100%;
}
#shadow {
display: none;
position: absolute;
left: 0;
top: 0;
background: black;
opacity: 0.7;
z-index: 10;
width: 100%;
height: 100%;
}
的JavaScript
$('.box').hover(function() {
$(this).addClass('hover');
$('#shadow').show();
}, function() {
$(this).removeClass('hover');
$('#shadow').hide();
});
我已经挖了上这么几个问题,但没有一个人回答如何摆脱闪烁的。
为什么不去做一个单独悬停你的影子,所以它显示在盒子包装悬停 – Pete
因为我需要知道哪个孩子触发悬停,所以我可以添加一个类到它 –
实际上看过你的代码,它是不可能做你想要的,如果你确实隐藏了覆盖层(这是导致闪烁的原因),所以没有办法ö悬停在另一个框和非悬停框在覆盖 – Pete