I want my background image to change when the mouse hovers over each menu item. My code works but, when the images fadeout
and fadein
, there is a white flash in between. To remove it, I want the images to cross-fade instead of just fading out and in.
How I can achieve this?
$(document).ready(function() {
$(".home-menu-list li a").mouseenter(function() {
var bannerClass = '#home-banner-' + $(this).attr('id');
$('.active-banner').not(bannerClass).stop().fadeOut().removeClass('active-banner');
$(bannerClass).stop().fadeIn().addClass('active-banner');
});
});
.main-banner-wrapper img {
height: 50px;
width: 100%;
object-fit: cover;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container-fluid ">
<div id="home-banner-1" class="active-banner">
<div class="main-banner-wrapper">
<img src="http://farm6.staticflickr.com/5145/5576437826_940f2db110.jpg" alt="Image 1" class="upload">
</div>
<div class="col-md-4 col-sm-6 visible-lg visible-md visible-sm front-text">
<p>Thethe world.</p>
</div>
</div>
<div id="home-banner-2" style="display:none">
<div class="main-banner-wrapper">
<img src="http://farm4.staticflickr.com/3611/3463265789_586ce40aef.jpg" class="upload">
</div>
<div class="col-md-4 col-sm-6 visible-lg visible-md visible-sm front-text">
<p>Thethe world.</p>
</div>
</div>
<div id="home-banner-3" style="display:none">
<div class="main-banner-wrapper">
<img src="http://farm6.staticflickr.com/5263/5601183065_f88a48d599.jpg" class="upload">
</div>
<div class="col-md-4 col-sm-6 visible-lg visible-md visible-sm front-text">
<p>The around the world.</p>
</div>
</div>
</div>
<!--content-->
<div class="container-fluid">
<div class="main-logo-panel">
<div class="box">
<div class="col-md-12 col-sm-12 ">
<div class="col-md-3 col-sm-3 col-xs-4 main-logo"></div>
<div class="col-md-9 col-sm-9 col-xs-8 main-menu">
<ul class="list-inline home-menu-list">
<li><a href="#" id="1">Rigging</a>
</li>
<li><a href="#" id="2">Hatches </a>
</li>
<li><a href="#" id="3">Stoppers</a>
</li>
</ul>
</div>
</div>
</div>
</div>
</div>
View on JsFiddle
You can achieve almost the same using CSS.
Some small CSS changes:
add transition: opacity 1s ease-in-out;
to the .main-banner-wrapper img
and add the following CSS:
.container-fluid .active-banner img {
opacity:1; }
.container-fluid img {
opacity:0; }
and remove the .fadeOut()
and .fadeIn()
from the jQuery
see the example on http://jsfiddle.net/m92aotbd/2/