首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用jQuery更改背景位置

使用jQuery更改背景位置
EN

Stack Overflow用户
提问于 2009-11-22 06:09:46
回答 5查看 126.1K关注 0票数 35

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

HTML:

代码语言:javascript
运行
复制
<div id="carousel">
    <ul id="submenu">
        <li>Apple</li>
        <li>Orange</li>
    </ul>
</div>

CSS:

代码语言:javascript
运行
复制
#carousel { 
    float: left;
    width: 960px;
    height: 360px;
    background: url(../images/carousel.png);
}

对如何做到这一点有什么建议吗?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-11-22 06:31:42

这就是了:

代码语言:javascript
运行
复制
$(document).ready(function(){
    $('#submenu li').hover(function(){
        $('#carousel').css('background-position', '10px 10px');
    }, function(){
        $('#carousel').css('background-position', '');
    });
});
票数 45
EN

Stack Overflow用户

发布于 2010-04-11 20:10:50

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

代码语言:javascript
运行
复制
#carousel li { background-position:0px 0px; }
#carousel li:hover { background-position:100px 0px; }
票数 27
EN

Stack Overflow用户

发布于 2013-04-19 01:20:32

rebellion上面的答案实际上是行不通的,因为对于CSS来说,“后台位置”实际上是“后台位置-x”和“后台位置-y”的缩写,所以他的代码的正确版本应该是:

代码语言:javascript
运行
复制
$(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个小时的时间才意识到这一点。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1776950

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档