jquery - 悬停时多个元素之间的无缝淡入淡出(jquery)

标签 jquery html css

在 jquery 中非常新,但我希望在悬停在按钮上时在背景之间淡入淡出(在本例中,多个替代 div 位于父 div 中)。我当前的代码在这方面是有用的,但仅限于将鼠标悬停在按钮上,然后鼠标悬停。但是,如果您在不松开鼠标的情况下直接从一个按钮转到另一个按钮,则会中断悬停,并且会打乱按钮调用各自 div 的顺序。

谁能帮我解决这个问题,在这些元素之间使用无缝淡入/淡出?如果其他方法更有效,我愿意接受它们(任何帮助我的业余代码枯竭的方法都将非常出色)。

这是我的代码:

$(document).ready(function() {

  $('#b1').hover(function() {
    if ($('.int').is(":visible")) {
      $('.int').fadeOut(300);

    } else {
      $("#i1").fadeIn(1000)
    }

  });

  $('#b2').hover(function() {
    if ($('.int').is(":visible")) {
      $('.int').fadeOut(300);

    } else {
      $("#i2").fadeIn(1000)
    }

  });

  $('#b3').hover(function() {
    if ($('.int').is(":visible")) {
      $('.int').fadeOut(300);

    } else {
      $("#i3").fadeIn(1000)
    }

  });



});
    .hold {
      background: green;
      width: 100%;
      height: 100vh;
      margin: 0 auto;
      float: left;
      position: absolute;
      z-index: 0;
    }
    .int {
      width: 100%;
      height: 100vh;
      float: left;
      display: none;
    }
    #i1 {
      background: red;
    }
    #i2 {
      background: blue;
    }
    #i3 {
      background: orange;
    }
    #b1 {
      background: purple;
      height: 50px;
      width: 80px;
      float: left;
    }
    #b2 {
      background: purple;
      height: 50px;
      width: 80px;
      float: left;
    }
    #b3 {
      background: purple;
      height: 50px;
      width: 80px;
      float: left;
    }
    .banner {
      width: 100%;
      height: 70px;
      background: purple;
      margin: 0px auto;
      z-index: 3;
      float: left;
      display: inline-block;
      position: absolute;
      bottom: 15px;
    }
    * {
      margin: 0;
    }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<body>

  <div class="banner">
    <button id="b1">
    </button>
    <button id="b2">
    </button>
    <button id="b3">
    </button>
  </div>

  <div class="hold" id="hold1">
    <div class="int" id="i1">
    </div>
    <div class="int" id="i2">
    </div>
    <div class="int" id="i3">
    </div>
  </div>

在此先感谢您的帮助!

最佳答案

我不是 100% 确定这种效果是否是您想要的。如下所示,淡出发生,然后紧接着是新颜色的淡入。无论如何,检查一下,看看它是否有帮助。

将这些自定义 HTML 属性添加到您的按钮。

<button id="b1" data-intId="#i1"></button>
<button id="b2" data-intId="#i2"></button>
<button id="b3" data-intId="#i3"></button>

然后,如下修改你的JavaScript

<script>
$(document).ready(function() {

    var ints = $('.int'); // I'm not really sure what 'int' refers to
    var buttons = $('button'); // could be changed if more buttons added later, maybe using a class, like int

    buttons.mouseenter(function () {
        var newInt = $(this).attr('data-intId');
        $(newInt).fadeIn(1000);
    });

    buttons.mouseout(function() {
        if (ints.is(":visible")) {
            ints.fadeOut(300);
        }
    })

});

关于整理代码的几个注意事项(您将在上面的注释中看到)- 首先尝试将任何重要的、经常重复出现的选择器保存为变量。这不仅可以帮助您编写,而且在性能方面也更便宜。每次您发送您的小 jQuery 妖精* 以在 DOM 树中查找选择器时,它都会耗尽资源。如果您可以立即找到所需的任何内容,然后存储这些元素,那就更好了。

另外,我借此机会使用了 HTML 的 data-* 属性,您可以完全按照自己的意愿创建这些属性。我在这里创建了一个,其中包含您要突出显示的 div 的 ID。

如果要对您的命名更具描述性,我的最后一条建议。对于这些情况,像“int”、“i1”和“b1”这样的东西可能没问题,但是一旦你的元素增长或其他人也在处理它,你可能会浪费很多时间来弄清楚你叫什么以及为什么。

*jQuery leprechaun 肯定不是官方术语(据我所知),它只是我自发想到的。另请注意,我不是 jQuery 专家,我几个月前才开始。

关于jquery - 悬停时多个元素之间的无缝淡入淡出(jquery),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36379676/

相关文章:

CSS 对齐文本垂直居中/居中

javascript - 有条件地加载具有屏幕宽度的js文件

javascript - 从函数内调用 setInterval

javascript - jquery 无法在 Sortable 中获取拖动项目 ID

javascript - 在下拉列表中显示的时间

javascript - 单击 <tr> 上的事件监听器

javascript - 当点击发生在指定元素之外时如何执行操作

jquery - 用于交换 ul li 的 toggleClass

javascript - 使用php浏览时写入文件的完整路径

css - 背景图片位置dompdf css2