想要实现如下效果:
每当悬停在一个.head上
一个蓝色.child滑动渐显
离开该.head进入另一个.head后
前者的.child滑动渐消,后者的.child滑动渐显若只有一个.head 动画大概是这样子:<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>audio</title>
<script src='http://code.jquery.com/jquery-1.8.3.min.js'></script>
<style>
.container{
position: relative;
}
.head{
position: relative;
background: #000;
height: 200px;
}
.child{
position: absolute;
background: #498af2;
width: 100px;
height: 100px;
opacity: 0;
}
</style>
</head>
<body>
<div class='head'>
<div class='child'></div>
</div>
</body>
<script>
$(function(){
$('.head').mouseover(function() {
$('.child').stop(true, false).animate({
left: '150px',
opacity: '1'
}, 500); }).mouseout(function() {
$('.head').children().stop(true,false).animate({
left: '0',
opacity: '0'
},500); });
});
</script>
</html>
但若有多个.head 在进入另外一个.head时,就没渐消的效果,而且一悬停在.child上动画又重新开始,不知道怎么实现类似上例的效果<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>audio</title>
<script src='http://code.jquery.com/jquery-1.8.3.min.js'></script>
<script src='script.js'></script>
<style>
.container{
position: relative;
}
.head{
position: relative;
background: orange;
height: 200px;
}
.child{
position: absolute;
background: #498af2;
width: 100px;
height: 100px;
opacity: 0;
}
</style>
</head>
<body>
<div class='container'>
<div class='head'></div>
<div class='head'></div>
<div class='head'></div>
</div>
</body>
</html>
$(function(){
$('.container .head').mouseover(function(){
$(this).append("<div class='child'></div>");
$('.child').stop(true,false).animate({
left: '150px',
opacity: '1'
},500);
}).mouseout(function(){
$(this).children().stop(true,false).animate({
left: '0',
opacity: '0'
},500);
$(this).children().remove();
});
});
每当悬停在一个.head上
一个蓝色.child滑动渐显
离开该.head进入另一个.head后
前者的.child滑动渐消,后者的.child滑动渐显若只有一个.head 动画大概是这样子:<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>audio</title>
<script src='http://code.jquery.com/jquery-1.8.3.min.js'></script>
<style>
.container{
position: relative;
}
.head{
position: relative;
background: #000;
height: 200px;
}
.child{
position: absolute;
background: #498af2;
width: 100px;
height: 100px;
opacity: 0;
}
</style>
</head>
<body>
<div class='head'>
<div class='child'></div>
</div>
</body>
<script>
$(function(){
$('.head').mouseover(function() {
$('.child').stop(true, false).animate({
left: '150px',
opacity: '1'
}, 500); }).mouseout(function() {
$('.head').children().stop(true,false).animate({
left: '0',
opacity: '0'
},500); });
});
</script>
</html>
但若有多个.head 在进入另外一个.head时,就没渐消的效果,而且一悬停在.child上动画又重新开始,不知道怎么实现类似上例的效果<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>audio</title>
<script src='http://code.jquery.com/jquery-1.8.3.min.js'></script>
<script src='script.js'></script>
<style>
.container{
position: relative;
}
.head{
position: relative;
background: orange;
height: 200px;
}
.child{
position: absolute;
background: #498af2;
width: 100px;
height: 100px;
opacity: 0;
}
</style>
</head>
<body>
<div class='container'>
<div class='head'></div>
<div class='head'></div>
<div class='head'></div>
</div>
</body>
</html>
$(function(){
$('.container .head').mouseover(function(){
$(this).append("<div class='child'></div>");
$('.child').stop(true,false).animate({
left: '150px',
opacity: '1'
},500);
}).mouseout(function(){
$(this).children().stop(true,false).animate({
left: '0',
opacity: '0'
},500);
$(this).children().remove();
});
});
解决方案 »
- xmlhttp.open();
- javascript自适应高度在IE7.0下有问题。获得的offsetHeight值比在FireFox下得到的大不少
- 请问这样的形式代表什么
- 我的JS库需要兼容Opera,不过我在这方便的经验很少,给点提示
- 小女刚学js.迷茫中。。。求大牛赐教。。。题目越长越好,越长越好,越长越好,越长越好,越长越好,越长越好,越长越好,越长越好,越长越好,越长越好,越长越好。。。
- javascript中正则表达式截取字符串问题
- firefox浏览器输入框的输入提示响应回车操作错误
- 在javascript中如何将session的值传递?
- 100分求美术家帮我网页美化一下,好了再加100分.分不够可再加
- 如何在一个JSP页面中优先显示图片,也就是说如何在进入网页时先下载图片
- js :如何实现滑块
- 游览器F11是全屏游览效果,有什么办法让用户不按F11用js实现这个效果吗?
当鼠标由head A移到head B时,按你的意思理应只是head B拥有mouseover响应,但上诉做法使head A也响应
mouseover。
建议每个head都定义id,用id来选择元素响应相应的鼠标事件。
$(".sz").mouseover(function() {//隐藏或显示移动应用
if ($("#yingYong1").is(":hidden")) {
$("#yingYong1").slideDown();
} else {
$("#yingYong1").slideUp();
}
if ($("#yingYong1").hasClass("szZ")) {
$(".sz").toggleClass("sz");
} else {
$(".sz").toggleClass("szZ");
} });
});
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>audio</title>
<script src='http://code.jquery.com/jquery-1.8.3.min.js'></script>
<style>
.container{
position: relative;
}
.head{
position: relative;
background: #000;
height: 200px;
}
.child{
position: absolute;
background: #498af2;
width: 100px;
height: 100px;
opacity: 0;
}
</style>
</head>
<body>
<div class='head'>
<div class='child'></div>
</div>
<div class='head'>
<div class='child'></div>
</div>
<div class='head'>
<div class='child'></div>
</div>
</body>
<script>
$(function(){
$('.head').mouseover(function() {
$(this).find('.child').stop(true, false).animate({
left: '150px',
opacity: '1'
}, 500); }).mouseout(function() {
$(this).find('.child').stop(true,false).animate({
left: '0',
opacity: '0'
},500); });
});
</script>
</html>
$(this).append("<div class='child'></div>");
$('.child').stop(true,false).animate({
left: '150px',
opacity: '1'
},500);
})
只想说 你js写错了 把 $('.child') 变成$(this).find(".child")就ok了