- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在 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/
我是一名优秀的程序员,十分优秀!