是否可以用CSS设置背景图像的大小?

我想做的事情是:

background: url('bg.gif') top repeat-y;
background-size: 490px;

但这样做似乎是完全错误的……


当前回答

不可能的。背景总是尽可能的大,但是你可以用background-repeat来阻止它重复自己。

background-repeat: no-repeat;

其次,背景不会进入框的边距区域,所以如果你想让背景只在框的实际内容上,你可以使用边距而不是填充。

第三,你可以控制背景图像的起始位置。默认情况下,它是一个框的左上角,但你可以通过background-position来控制它,就像这样:

background-position: center top;

或者

background-position: 20px -14px;

CSS精灵经常使用负定位。

其他回答

不可能的。背景总是尽可能的大,但是你可以用background-repeat来阻止它重复自己。

background-repeat: no-repeat;

其次,背景不会进入框的边距区域,所以如果你想让背景只在框的实际内容上,你可以使用边距而不是填充。

第三,你可以控制背景图像的起始位置。默认情况下,它是一个框的左上角,但你可以通过background-position来控制它,就像这样:

background-position: center top;

或者

background-position: 20px -14px;

CSS精灵经常使用负定位。

如果你的用户只使用Opera 9.5+, Safari 3+, Internet Explorer 9+和Firefox 3.6+,那么答案是肯定的。否则,没有。

background-size属性是css3的一部分,但它不能在大多数浏览器上工作。

为了您的目的,只需将实际图像放大。

你完全可以用CSS3:

body {
    background-image: url(images/bg-body.png); 
    background-size: 100%; /* size the background image at 100% like any responsive img tag */
    background-position: top center;
    background-repeat:no-repeat;
 }

这将把背景图像的大小调整为主体元素宽度的100%,然后根据较小的分辨率调整主体元素的大小,相应地调整背景的大小。

示例如下:http://www.sccc.premiumdw.com/examples/resize-background-images-with-css/

您无法使用当前版本的CSS(2.1)设置背景图像的大小。

您只能设置:位置,固定,图像-url,重复模式和颜色。

你可以使用两个<div>元素:

一个是容器(它是您最初想要的容器) 背景图像出现在)。 第二个包含在。您将其大小设置为 背景图像(或您希望显示的大小)。

然后将包含的div设置为绝对位置。这样它就不会干扰包含div中的项目的正常流动。

它使你能够有效地使用精灵图像。