日期:2014-05-16 浏览次数:20374 次
<!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);//渐出 }) })