悬停时淡入CSS变化
有 4 个 div。所有都有背景图像,当您将鼠标悬停在 div1 上时,脚本应该更改 div 2、3、4 中的背景图像。这应该是动画的(淡入?)。
这是经过几个小时的 jquery“边做边学”后得到的代码,但我无法让 jquery 对其进行动画处理。
html:
<div class="categories" style="color:#ccc;">
<div class="single_cat first"></div>
<div class="single_cat second"></div>
<div class="single_cat third"></div>
<div class="single_cat fourth"></div>
</div>
css:
#tour .categories{
width: 950px;
height: 236px;
background-color: #efefef;
margin: 20px 0 0 0;
}
.single_cat {
width: 236px;
height: inherit;
margin: 0 2px 0 0;
float: left;
background-color: #222;
color: #fff;
}
.single_cat.fourth {
width: 236px;
height: inherit;
margin: 0;
float: left;
background-color: #222;
}
.single_cat.first {
background-image:url('/img/takethetour/r_text.png');
}
.single_cat.second {
background-image:url('/img/takethetour/b_text.png');
}
.single_cat.third {
background-image:url('/img/takethetour/c_text.png');
}
.single_cat.fourth {
background-image:url('/img/takethetour/bou_text.png');
}
jquery (java):
$(".first").mouseover(function() {
$(".second").css('background', 'url(/img/takethetour/r_2.png)');
$(".third").css('background', 'url(/img/takethetour/r_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/r_4.png)');
}).mouseout(function(){
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".second").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/b_2.png)');
$(".third").css('background', 'url(/img/takethetour/b_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/b_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".third").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/c_2.png)');
$(".second").css('background', 'url(/img/takethetour/c_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/c_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".fourth").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/bou_2.png)');
$(".third").css('background', 'url(/img/takethetour/bou_3.png)');
$(".second").css('background', 'url(/img/takethetour/bou_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
});
there are 4 divs. All have background images, when you hover over div1, the script should change the background image in div 2, 3, 4. This should be animated (fadein?).
This is the code it got after hours of jquery "learning by doing" but i couldn't get jquery to animate it.
html:
<div class="categories" style="color:#ccc;">
<div class="single_cat first"></div>
<div class="single_cat second"></div>
<div class="single_cat third"></div>
<div class="single_cat fourth"></div>
</div>
css:
#tour .categories{
width: 950px;
height: 236px;
background-color: #efefef;
margin: 20px 0 0 0;
}
.single_cat {
width: 236px;
height: inherit;
margin: 0 2px 0 0;
float: left;
background-color: #222;
color: #fff;
}
.single_cat.fourth {
width: 236px;
height: inherit;
margin: 0;
float: left;
background-color: #222;
}
.single_cat.first {
background-image:url('/img/takethetour/r_text.png');
}
.single_cat.second {
background-image:url('/img/takethetour/b_text.png');
}
.single_cat.third {
background-image:url('/img/takethetour/c_text.png');
}
.single_cat.fourth {
background-image:url('/img/takethetour/bou_text.png');
}
jquery (java):
$(".first").mouseover(function() {
$(".second").css('background', 'url(/img/takethetour/r_2.png)');
$(".third").css('background', 'url(/img/takethetour/r_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/r_4.png)');
}).mouseout(function(){
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".second").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/b_2.png)');
$(".third").css('background', 'url(/img/takethetour/b_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/b_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".third").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/c_2.png)');
$(".second").css('background', 'url(/img/takethetour/c_3.png)');
$(".fourth").css('background', 'url(/img/takethetour/c_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
$(".fourth").css('background', 'url(/img/takethetour/bou_text.png)');
});
$(".fourth").mouseover(function() {
$(".first").css('background', 'url(/img/takethetour/bou_2.png)');
$(".third").css('background', 'url(/img/takethetour/bou_3.png)');
$(".second").css('background', 'url(/img/takethetour/bou_4.png)');
}).mouseout(function(){
$(".first").css('background', 'url(/img/takethetour/r_text.png)');
$(".third").css('background', 'url(/img/takethetour/c_text.png)');
$(".second").css('background', 'url(/img/takethetour/b_text.png)');
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
背景图像无法动画化。只能对颜色或其他标量值进行动画处理。
Background-Images cannot be animated. Only colors or other scalar values can be animated.
如果您正在寻找首先淡出的非悬停 div,然后随着新背景淡入,您将需要如下所示的内容:
If you're looking for the non-hovered divs to fade out first, then fade back in with the new backgrounds, you'll need something like this:
如果您需要背景图像直接从一张淡出到另一张,您可以尝试将一个 div 嵌套在另一个 div 中作为背景。将内部 div 的背景设置为默认背景,将外部 div 的背景设置为悬停背景。然后,您可以淡入和淡出内部 div。
请记住,您不想在内部背景 div 中放置任何内容,因为它会淡出(除非您想要) - 您需要另一个同级 div 来包含该内容。可能需要一些 CSS 才能正确定位所有内容,具体取决于您的页面布局方式。
这是其中之一的基本思想,但请记住,您可能需要处理 div 的位置和大小,以便它们正确重叠。
If you need the background images to fade directly from one to the other, you could try nesting one div inside the other for the background. Set the inner div's background to the default background, and the outer div's background to the hovered one. Then, you could fade the inner div in and out.
Remember that you won't want to place any content in the inner background div since it will fade out (unless that's what you want) - you'll want another sibling div to contain the content. It might take a bit of CSS to position everything correctly, depending on how you've got your page laid out.
This is the basic idea for one of them, but remember that you'll probably need to work with the positioning and sizing of the divs so that they overlap properly.
另一种方法可能是将它们作为 img 并使用较低的 z-index 进行样式化,将它们分层在其他内容后面。这可以产生与将它们作为“背景”相同的效果,而不受作为背景的限制 - 例如。现在可以使用 jquery fadeIn 对它们进行动画处理。有点老套,但完成了工作。
Another approach could be to have them as img's and style them with lower z-index, to layer them behind your other content. That can create the same effect as having them as "backgrounds" without having the restrictions of being backgrounds - eg. they can now be animated using jquery fadeIn. Kinda hacky, but gets the job done.