日期:2014-05-16 浏览次数:20457 次
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<style>
body{ margin:0; padding:0; font-size:12px; background:#fff}
ul, li{ margin:0; padding:0; list-style-type:none}
.main{ width:300px; margin:auto}
.list{ width:300px; float:left}
.list li{ width:100px; height:100px; float:left; margin:20px; background-color:#06C}
.windows{ width:200px; height:200px; display:none; float:left; background-color:#F90; position:relative; left:40px; margin-top:-80px; z-index:9999}
</style>
</head>
<body>
<div class="main">
<ul id="list" class="list">
<li></li>
<li></li>
</ul>
<div id="windows" class="windows"></div>
</div>
</body>
<script src="js/jquery-1.6.4.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(function(){
$("#list li").each(function(i,n){
$(n).mouseover(function(){
$("#windows").fadeTo(100,1);
}).mouseout(function(){
$("#windows").fadeTo(100,0);
})
});
})
</script>
</html>
<script type="text/javascript">
$(function(){
$("#list li").each( function() {
$(this).mouseover( function() {
$("#windows").fadeTo(100, 1);
}).mouseout( function(event) {
if (event.relatedTarget.id != 'windows') $("#windows").fadeOut(100, 0);
});
$("#windows").mouseout( function(event) {
if (event.relatedTarget.nodeName != 'LI') $(this).fadeOut(100, 0);
});
});
})
</script>
------解决方案--------------------
我猜楼主不但想移动到window上去让它不消失,也同时希望从window上移开之后它也消失,所以我帮楼主改动和加了一些代码
$(function() {
$("#list li").each(function(i, n) {
$(n).mouseover(function() {
$("#windows").stop().fadeIn(100);//fadein 代替fadeto,效果一样,简单一些
}).mouseout(function() {
$("#windows").stop().fadeOut(500); //fadeout 代替fadeto
})
});
$("#windows").mouseover(function() {
$(this).stop().fadeTo(0, 1);//立即显示
}).mouseout(function() {
$(this).fadeOut(500);//渐出
})
})