我正在尝试使用以下代码将jquery hover
函数分配给<ul>
列表中的所有元素:
var element = 0;
var length = $(".artist-list-link").length;
while (element<length) {
$(".artist-list-link:eq("+element+")").hover(function() {
$(".artist-back:eq("+element+")").css('display','block');
$(".artist-hover:eq("+element+")").fadeIn(100);
}, function() {
$(".artist-back:eq("+element+")").css('display','none');
$(".artist-hover:eq("+element+")").fadeOut(100);
});
element++;
};
标记看起来像这样:
<ul>
<li><a class="artist-list-link" href="">Artist 1</a></li>
<li><a class="artist-list-link" href="">Artist 2</a></li>
<li><a class="artist-list-link" href="">Artist 3</a></li>
<li><a class="artist-list-link" href="">Artist 4</a></li>
<li><a class="artist-list-link" href="">Artist 5</a></li>
</ul>
而且每个艺术家都有一些div(我删除了所有链接,只是为了让它更具可读性。
<div class="artist-thumbnail artist-size">
<div class="artist-card artist-size artist-hover"></div>
<div class="artist-card artist-size"><img src="" /></div>
<div class="artist-card artist-size artist-back">Artist 1</div>
</div>
但是上面的循环并没有真正起作用,尽管下面的代码运行完美:
$('.artist-list-link:eq(0)').hover(function() {
$('.artist-back:eq(0)').css('display','block');
$('.artist-hover:eq(0)').fadeIn(100);
}, function() {
$('.artist-back:eq(0)').css('display','none');
$('.artist-hover:eq(0)').fadeOut(100);
});
可能是什么问题?谢谢你的回答。
答案 0 :(得分:5)
这是因为element
在调用回调时发生了变化。
你可以这样做:
while (element<length) {
(function(element) {
$(".artist-list-link:eq("+element+")").hover(function() {
$(".artist-back:eq("+element+")").css('display','block');
$(".artist-hover:eq("+element+")").fadeIn(100);
}, function() {
$(".artist-back:eq("+element+")").css('display','none');
$(".artist-hover:eq("+element+")").fadeOut(100);
});
})(element);
element++;
};
这可以在闭包中保护元素的值。