jquery - 鼠标悬停时交叉淡入淡出 div

标签 jquery html css fade

我希望当鼠标悬停在每个菜单项上时我的背景图像发生变化。我的代码可以工作,但是当图像淡出淡入时,中间有白色闪光。要删除它,我希望图像交叉淡入淡出,而不仅仅是淡出和淡入。

我怎样才能实现这个目标?

$(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>

查看JsFiddle

最佳答案

啊,你就快到了。您只需要绝对位置,以防止第一个在交叉淡入淡出过程中向下碰撞下一个。

http://jsfiddle.net/te69783s/1/

.main-banner-wrapper img {
    height: 500px;
    width: 100%;
    object-fit: cover;
    position:absolute;
    top:0;
    left:0;
}

.container-fluid {
    height:500px;
}

关于jquery - 鼠标悬停时交叉淡入淡出 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31571024/

相关文章:

php - 如何使用 mPDF 和 PHP 防止 PDF 中的表格大小调整?

css - 为什么这些 div 会这样?

javascript - 防止滚动但 div 需要位置 :absolute

Python Beautiful Soup 提取 HTML 元数据

javascript - jQuery 相当于 Ajax 请求中 javascript 的 Transport.responseText 吗?

html - 包装时如何将单词和 Font Awesome 图标视为一个?

html - 将背景过滤器应用于 svg 路径元素

css - 为什么我的图标显示为空白方 block ?

php - 使用 PHP 或 jQuery 通过 ID 获取 Div 内的值

javascript - .val() 没有从输入中获取更新值