$('#d11,#d12').on('mouseover',function(){
$('#d2').animate({opacity:'100'});
});
如代码所示,在d11,d12之间移动,animate会执行照成物体一闪一闪的,怎么解决。
详细代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>Document</title>
<style>
#d1{overflow:hidden;}
#d1 p{height:50px;width:50px;float:left;}
#d11{background:#F11;}
#d12{background:#ff2;}
#d2{height:50px;width:100px;background:#000;opacity:0;filter:alpha(opacity=0);}
</style>
<script type="text/javascript" src="http://lib.sinaapp.com/js/jquery/1.12.4/jquery-1.12.4.min.js"></script>
</head>
<body>
<p id="d1">
<p id="d11"></p>
<p id="d12"></p>
</p>
<p id="d2"></p>
<script>
$(document).ready(function(){
$('#d11,#d12').on('mouseover',function(){
$('#d2').animate({opacity:'100'});
});
$('#d11,#d12').on('mouseout',function(){
$('#d2').animate({opacity:'0'});
});
});
</script>
</body>
</html>
方法1:
不需要js,css加一句:
不过得注意下d1宽度……
方法2:
加个新类
.opa1{opacity:1}
然后用addClass和removeClass做。animate前先stop掉动画。
或者用封装好的.hover()