在div之间滑动重复的背景图像

时间:2012-01-01 18:56:46

标签: jquery css animation background-image

如何使用jQuery创建在div之间滑动重复背景图像的效果?

看看我制作的这个简单的fiddle。我在CSS组合中使用addClass / removeClass jQuery函数来更改哪个div具有background-image。一切正常。

但是如果我想在每个div之间设置背景图像的滑动动画呢?

1 个答案:

答案 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');
}

以下是演示:http://jsfiddle.net/Hwvsb/3/