使用jQuery更改背景位置

时间:2009-11-21 22:09:46

标签: jquery css background-position

我想在悬停li元素时更改CSS类的背景位置。

HTML:

<div id="carousel">
    <ul id="submenu">
        <li>Apple</li>
        <li>Orange</li>
    </ul>
</div>

CSS:

#carousel { 
    float: left;
    width: 960px;
    height: 360px;
    background: url(../images/carousel.png);
}

有关如何执行此操作的任何建议吗?

5 个答案:

答案 0 :(得分:43)

你走了:

$(document).ready(function(){
    $('#submenu li').hover(function(){
        $('#carousel').css('background-position', '10px 10px');
    }, function(){
        $('#carousel').css('background-position', '');
    });
});

答案 1 :(得分:26)

你们这些事情变得复杂了。您可以通过CSS轻松完成此操作。

#carousel li { background-position:0px 0px; }
#carousel li:hover { background-position:100px 0px; }

答案 2 :(得分:3)

反叛的上述答案实际上不起作用,因为对于CSS,'background-position'实际上是'background-position-x'和'background-position-y'的简写,所以他的代码的正确版本将是:

$(document).ready(function(){
    $('#submenu li').hover(function(){
        $('#carousel').css('background-position-x', newValueX);
        $('#carousel').css('background-position-y', newValue);
    }, function(){
        $('#carousel').css('background-position-x', oldValueX);
        $('#carousel').css('background-position-y', oldValueY);
    });
});

我花了大约4个小时的时间撞击它,以达到加剧的目的。

答案 3 :(得分:2)

$('#submenu li').hover(function(){
    $('#carousel').css('backgroundPosition', newValue);
});

答案 4 :(得分:1)

backgroundPosition div中的li悬停时,carousel div上的submenu设置新值。当悬停结束时删除backgroundPosition并将backgroundPosition重置为旧值。

$('#submenu li').hover(function() {
    if ($('#carousel').data('oldbackgroundPosition')==undefined) {
        $('#carousel').data('oldbackgroundPosition', $('#carousel').css('backgroundPosition'));
    }
    $('#carousel').css('backgroundPosition', [enternewvaluehere]);
},
function() {
    var reset = '';
    if ($('#carousel').data('oldbackgroundPosition') != undefined) {
        reset = $('#carousel').data('oldbackgroundPosition');
        $('#carousel').removeData('oldbackgroundPosition');
    }
    $('#carousel').css('backgroundPosition', reset);
});