如何使用jQuery创建在div之间滑动重复背景图像的效果?
看看我制作的这个简单的fiddle。我在CSS组合中使用addClass
/ removeClass
jQuery函数来更改哪个div具有background-image。一切正常。
但是如果我想在每个div之间设置背景图像的滑动动画呢?
答案 0 :(得分:1)
您可以在文本后面制作一个动画背景div:
JS -
var $menu = $('#menu'),
$bg = $menu.children('.bg');
$menu.children().not($bg).click(function() {
var $this = $(this);
$menu.children('.active').removeClass('active');
$this.addClass('active');
$bg.css('opacity', 0.5).stop().animate({
left : $this.offset().left
}, 500, function() {
$(this).stop().animate({ opacity : 1 }, 250);
});
});
HTML -
<div id="menu">
<div class="active">
Item 1
</div>
<div>
Item 2
</div>
<div>
Item 3
</div>
<div class="bg"></div>
</div>
CSS -
#menu {
position : relative;
z-index : 1;
}
#menu > div {
z-index : 2;
display : inline-block;
height : 50px;
width : 150px;
text-align : center;
line-height : 2;
}
#menu .bg {
position : absolute;
z-index : -1;
top : 0;
left : 0;
background : transparent url('http://alexcoplan.co.uk/resources/active.png');
}