The background-size
CSS property sets the size of the element's background image.
The image can be left to its natural size, stretched, or constrained to fit the available space.
The background-size
CSS property sets the size of the element's background image.
The image can be left to its natural size, stretched, or constrained to fit the available space.
background-size: contain;
background-size: contain;
background-repeat: no-repeat;
background-size: cover;
background-size: 30%;
background-size: 200px 100px;
<section id="default-example">
<div class="transition-all" id="example-element"></div>
</section>
#example-element {
background-image: url("/shared-assets/images/examples/hand.jpg");
min-width: 100%;
min-height: 100%;
}
Spaces not covered by a background image are filled with the background-color
property, and the background color will be visible behind background images that have transparency/translucency.
/* Keyword values */
background-size: cover;
background-size: contain;
/* One-value syntax */
/* the width of the image (height becomes 'auto') */
background-size: 50%;
background-size: 3.2em;
background-size: 12px;
background-size: auto;
/* Two-value syntax */
/* first value: width of the image, second value: height */
background-size: 50% auto;
background-size: 3em 25%;
background-size: auto 6px;
background-size: auto auto;
/* Multiple backgrounds */
background-size: auto, auto; /* Not to be confused with `auto auto` */
background-size: 50%, 25%, 25%;
background-size: 6px, auto, contain;
/* Global values */
background-size: inherit;
background-size: initial;
background-size: revert;
background-size: revert-layer;
background-size: unset;
The background-size
property is specified in one of the following ways:
contain
or cover
.auto
.<percentage>
, or auto
.To specify the size of multiple background images, separate the value for each one with a comma.
contain
Scales the image as large as possible within its container without cropping or stretching the image.
If the container is larger than the image, this will result in image tiling, unless the background-repeat
property is set to no-repeat
.
cover
Scales the image (while preserving its ratio) to the smallest possible size to fill the container (that is: both its height and width completely cover the container), leaving no empty space. If the proportions of the background differ from the element, the image is cropped either vertically or horizontally.
auto
Scales the background image in the corresponding direction such that its intrinsic proportions are maintained.
<length>
Stretches the image in the corresponding dimension to the specified length. Negative values are not allowed.
<percentage>
Stretches the image in the corresponding dimension to the specified percentage of the background positioning area.
The background positioning area is determined by the value of background-origin
(by default, the padding box).
However, if the background's viewport.
Negative values are not allowed.
The computation of values depends on the image's intrinsic dimensions (width and height) and intrinsic proportions (width-to-height ratio). These attributes are as follows:
<gradient>
s have no intrinsic dimensions or intrinsic proportions.element()
function use the intrinsic dimensions and proportions of the generating element.Note:
In Gecko, background images created using the element()
function are currently treated as images with the dimensions of the element, or of the background positioning area if the element is SVG, with the corresponding intrinsic proportion. This is non-standard behavior.
Based on the intrinsic dimensions and proportions, the rendered size of the background image is computed as follows:
If both components of background-size
are specified and are not auto
: The background image is rendered at the specified size.
If the background-size
is contain
or cover
: While preserving its intrinsic proportions, the image is rendered at the largest size contained within, or covering, the background positioning area.
If the image has no intrinsic proportions, then it's rendered at the size of the background positioning area.
If the background-size
is auto
or auto auto
:
contain
had been specified instead.Note:
SVG images have a preserveAspectRatio
attribute that defaults to the equivalent of contain
; an explicit background-size
causes preserveAspectRatio
to be ignored.
If the background-size
has one auto
component and one non-auto
component:
Note: Background sizing for vector images that lack intrinsic dimensions or proportions is not yet fully implemented in all browsers. Be careful about relying on the behavior described above, and test in multiple browsers to be sure the results are acceptable.
Inherited | no | |
---|---|---|
Percentages | relative to the background positioning area | |
[ <length-percentage [0,∞]> | cover <percentage> ExamplesTiling a large imageLet's consider a large image, a 2982x2808 Firefox logo image. We want to tile four copies of this image into a 300x300-pixel element.
To do this, we can use a fixed HTMLhtml
CSScss
ResultSee Resizing background images for more examples. Specifications
Browser compatibilitySee also |