gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-04 13:08:48 25 4
gpt4 key购买 nike

在 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com