我有一个测试设置,缩略图div变成了另一个div,但是它有一些问题。
下面是代码:
Javacript:
<script type="text/javascript">
$(document).ready(function(){
$(".phase-2").hide();
});
$(function(){
$('.grid-box').hover(
function(){
$('.grid-box .phase-1').fadeOut(300, function(){
$('.grid-box .phase-2').fadeIn(300);
});
},
function(){
$('.grid-box .phase-2').fadeOut(300, function(){
$('.grid-box .phase-1').fadeIn(300);
});
}
);
});
</script>HTML:
<div class="grid-box">
<div class="phase-1">
<img class="grid-image" src="http://teamworksdesign.com/v2/wp-content/themes/default/images/dtr.jpg" alt="" height="152" width="210" />
<div class="grid-heading">
<h2>DTR Medical</h2>
<h3>Branding, Web, Print</h3>
</div>
</div>
<div class="phase-2">
<div class="grid-info">
<h4>Probeything 2000</h4>
<p>Marketing unglamorous single-use medical intruments is not simple. We helped Neurosign increasetheir sales by 25% and increasemarket awareness.</p>
</div>
<div class="grid-heading-hover">
<h2>DTR Medical</h2>
<h3>Branding, Web, Print</h3>
</div>
</div>
发布于 2011-05-17 10:10:12
1)不要在回调上执行悬停项的fadeIn,而是立即执行。这将防止白色背景显示:
$('.grid-box .phase-1').fadeOut(300);
$('.grid-box .phase-2').fadeIn(300);2)最简单的方法是在缩略图容器上指定一个大小并将overflow: hidden;添加到其中。
3)最后,以下代码将确保仅包含在悬停的div中的元素将受到影响:
$(function(){
$('.grid-box').hover(
function(){
$('.phase-1', this).fadeOut(300);
$('.phase-2', this).fadeIn(300);
},
function(){
$('.phase-2', this).fadeOut(300)
$('.phase-1', this).fadeIn(300);
}
);
});发布于 2011-05-17 10:32:41
<div class="grid-box">
<div class="phase-1"></div>
<div class="phase-2"></div>
</div>JQ
$(document).click(function (){
$('.grid-box .phase-1').animate({opacity:50},2000).queue(function(){
$(this).hide();
});
$('.grid-box .phase-2').fadeIn(2000);
});CSS
.phase-1{width: 100px;height: 100px;background: red; position:absolute;}
.phase-2{width: 100px;height: 100px;background: blue;display: none; position:absolute;}我知道这并不完全是您的代码的样子,但是您可以在简单的解释中看到我的意思。
下面是它在jsfiddle http://jsfiddle.net/NxJf8/中的演示
https://stackoverflow.com/questions/6029160
复制相似问题