我有一个图像列表,我希望在用户单击列表中的链接后淡出然后淡入。出于某种原因,当我单击列表中的链接时,该项目将淡入,但就在它完成淡入之前,它会淡出并很快恢复!
$(document).ready(function(){
$('.service-link').click(function(){ return switch_service(this); });
});
function switch_service( link ) {
var slug = $(link).attr('href');
$('.active').removeClass('active');
$(link).addClass('active');
$('.service-li:visible').fadeOut( 300, function(){
$(slug).fadeIn( 300 );
} );
return false;
}
HTML 看起来像这样:
<ul id="services-info">
<li class="service-li" id="slug-1"><img src="..." /></li>
<li class="service-li" id="slug-2"><img src="..." /></li>
<li class="service-li" id="slug-3"><img src="..." /></li>
<li class="give-height"></li>
</ul>
<ul id="services-list">
<li><a class="service-link" href="#slug-1">Test 1</a></li>
<li><a class="service-link" href="#slug-2">Test 2</a></li>
<li><a class="service-link" href="#slug-3">Test 3</a></li>
</ul>
我不确定有什么不同。我以前做过这种事情,没有问题。有时功能可能会因为项目之间的快速点击而有点不稳定,但这次每次都会发生(在 FF 和 Chrome 中测试)。
编辑:好的,所以我通过添加额外的 ID 和一个带有类的空列表项来使我的示例更忠实于我的页面上运行的内容,以防止我的 ul 隐藏元素折叠。我最初没有发布我的 CSS,因为我没有想到这可能是问题所在,这里是:
#services-list,
#services-info {
margin: 0px;
padding: 0px;
display: block;
width: 465px;
float: left;
list-style-type: none;
font-size: 21px;
line-height: 40px;
height: 100%;
position: relative;
}
#services-list:after,
#services-info:after {
content: "";
display: block;
clear: both;
}
#services-info > li {
text-align: center;
position: absolute;
}
#services-list {
padding-left: 50px;
color: #cacaca;
}
#services-list a {
color: #cacaca;
}
#services-list a.active {
color: #bed545;
}
#services-info .give-height {
display: block;
min-height: 30px;
}
#services-info > li {
display: none;
text-align:center;
vertical-align: middle;
height: 100%;
position: relative;
}
为了准确显示发生了什么,这是测试链接,但是一旦回答了这个问题,我就会将其删除(对于将来可能遇到此问题的人感到抱歉,希望我能很好地描述该问题以使其仍然有用)