使用jQuery更改背景位置

Mat*_*ats 33 css jquery background-position

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

HTML:

<div id="carousel">
    <ul id="submenu">
        <li>Apple</li>
        <li>Orange</li>
    </ul>
</div>
Run Code Online (Sandbox Code Playgroud)

CSS:

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

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

reb*_*ion 44

干得好:

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

  • 什么是`newValue`的有效值?它是一个字符串?它是什么格式的? (20认同)

小智 27

你们这些事情很复杂.你可以从CSS简单地做到这一点.

#carousel li { background-position:0px 0px; }
#carousel li:hover { background-position:100px 0px; }
Run Code Online (Sandbox Code Playgroud)

  • @meo我很想说"谁在乎?" 但是唉.IE6. (15认同)
  • IE6终于死了,连MS都不关心它 (15认同)
  • 每个人都知道IE6是撒旦的化身.任何仍在使用IE6的人都是邪恶的伴侣或政府雇员. (5认同)

Kar*_*ren 6

上面叛乱的答案实际上是行不通的,因为对于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);
    });
});
Run Code Online (Sandbox Code Playgroud)

我花了大约4个小时将自己的头撞在上面,才意识到这一点。