35

我想在悬停 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);
}

关于如何做到这一点的任何建议?

4

5 回答 5

45

干得好:

$(document).ready(function(){
    $('#submenu li').hover(function(){
        $('#carousel').css('background-position', '10px 10px');
    }, function(){
        $('#carousel').css('background-position', '');
    });
});
于 2009-11-21T22:31:42.480 回答
27

你们把事情复杂化了。你可以从 CSS 简单地做到这一点。

#carousel li { background-position:0px 0px; }
#carousel li:hover { background-position:100px 0px; }
于 2010-04-11T12:10:49.980 回答
6

rebellion 上面的回答实际上不起作用,因为对于 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 个小时的时间撞到它,才意识到这一点令人恼火。

于 2013-04-18T17:20:32.420 回答
3
$('#submenu li').hover(function(){
    $('#carousel').css('backgroundPosition', newValue);
});
于 2009-11-21T22:11:45.847 回答
2

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

$('#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);
});
于 2009-11-21T22:21:08.370 回答