<feBlend>
<feColorMatrix>
<feComponentTransfer>
<feComposite>
<feConvolveMatrix>
<feDiffuseLighting>
<feDisplacementMap>
<feDistantLight>
<feFlood>
<feFuncA>
<feFuncB>
<feFuncG>
<feFuncR>
<feGaussianBlur>
<feImage>
<feMerge>
<feMergeNode>
<feMorphology>
<feOffset>
<fePointLight>
<feSpecularLighting>
<feSpotLight>
<feTile>
<feTurbulence>
<filter>
<font>
<font-face>
<font-face-format>
<font-face-name>
<font-face-src>
<font-face-uri>
<foreignObject>
preserveAspectRatio
attribute indicates how an element with a viewBox providing a given aspect ratio must fit into a viewport with a different aspect ratio.
Because the aspect ratio of an SVG image is defined by the
viewBox
attribute, if this attribute isn't set, the
preserveAspectRatio
attribute has no effect (
with one exception, the
<image>
element, as described below
).
<svg viewBox="-1 -1 162 92" xmlns="http://www.w3.org/2000/svg">
<defs>
<path id="smiley" d="M50,10 A40,40,1,1,1,50,90 A40,40,1,1,1,50,10 M30,40 Q36,35,42,40 M58,40 Q64,35,70,40 M30,60 Q50,75,70,60 Q50,75,30,60" />
</defs>
<!-- (width>height) meet -->
<rect x="0" y="0" width="20" height="10">
<title>xMidYMid meet</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMidYMid meet" x="0" y="0">
<use href="#smiley" />
</svg>
<rect x="25" y="0" width="20" height="10">
<title>xMinYMid meet</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMinYMid meet" x="25" y="0">
<use href="#smiley" />
</svg>
<rect x="50" y="0" width="20" height="10">
<title>xMaxYMid meet</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMaxYMid meet" x="50" y="0">
<use href="#smiley" />
</svg>
<!-- (width>height) slice -->
<rect x="0" y="15" width="20" height="10">
<title>xMidYMin slice</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMidYMin slice" x="0" y="15">
<use href="#smiley" />
</svg>
<rect x="25" y="15" width="20" height="10">
<title>xMidYMid slice</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMidYMid slice" x="25" y="15">
<use href="#smiley" />
</svg>
<rect x="50" y="15" width="20" height="10">
<title>xMidYMax slice</title>
</rect>
<svg viewBox="0 0 100 100" width="20" height="10"
preserveAspectRatio="xMidYMax slice" x="50" y="15">
<use href="#smiley" />
</svg>
<!-- (width<height) meet -->
<rect x="75" y="0" width="10" height="25">
<title>xMidYMin meet</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMidYMin meet" x="75" y="0">
<use href="#smiley" />
</svg>
<rect x="90" y="0" width="10" height="25">
<title>xMidYMid meet</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMidYMid meet" x="90" y="0">
<use href="#smiley" />
</svg>
<rect x="105" y="0" width="10" height="25">
<title>xMidYMax meet</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMidYMax meet" x="105" y="0">
<use href="#smiley" />
</svg>
<!-- (width<height) slice -->
<rect x="120" y="0" width="10" height="25">
<title>xMinYMid slice</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMinYMid slice" x="120" y="0">
<use href="#smiley" />
</svg>
<rect x="135" y="0" width="10" height="25">
<title>xMidYMid slice</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMidYMid slice" x="135" y="0">
<use href="#smiley" />
</svg>
<rect x="150" y="0" width="10" height="25">
<title>xMaxYMid slice</title>
</rect>
<svg viewBox="0 0 100 100" width="10" height="25"
preserveAspectRatio="xMaxYMid slice" x="150" y="0">
<use href="#smiley" />
</svg>
<!-- none -->
<rect x="0" y="30" width="160" height="60">
<title>none</title>
</rect>
<svg viewBox="0 0 100 100" width="160" height="60"
preserveAspectRatio="none" x="0" y="30">
<use href="#smiley" />
</svg>
</svg>
path {
fill: yellow;
stroke: black;
stroke-width: 8px;
stroke-linecap: round;
stroke-linejoin: round;
pointer-events: none;
}
rect:hover, rect:active {
outline: 1px solid red;
}
preserveAspectRatio="<align> [<meetOrSlice>]"
Its value is made of one or two keywords: A required alignment value and an optional "meet or slice" reference as described below:
The alignment value indicates whether to force uniform scaling and, if so, the alignment method to use in case the aspect ratio of the
viewBox
doesn't match the aspect ratio of the viewport. The alignment value must be one of the following keywords:
<align>
is
none
, then the optional
<meetOrSlice>
value is ignored
.
<min-x>
of the element's
viewBox
with the smallest X value of the viewport.
Align the
<min-y>
of the element's
viewBox
with the smallest Y value of the viewport.
viewBox
with the midpoint X value of the viewport.
Align the
<min-y>
of the element's
viewBox
with the smallest Y value of the viewport.
<min-x>+<width>
of the element's
viewBox
with the maximum X value of the viewport.
Align the
<min-y>
of the element's
viewBox
with the smallest Y value of the viewport.
<min-x>
of the element's
viewBox
with the smallest X value of the viewport.
Align the midpoint Y value of the element's
viewBox
with the midpoint Y value of the viewport.
viewBox
with the midpoint X value of the viewport.
Align the midpoint Y value of the element's
viewBox
with the midpoint Y value of the viewport.
<min-x>+<width>
of the element's
viewBox
with the maximum X value of the viewport.
Align the midpoint Y value of the element's
viewBox
with the midpoint Y value of the viewport.
<min-x>
of the element's
viewBox
with the smallest X value of the viewport.
Align the
<min-y>+<height>
of the element's
viewBox
with the maximum Y value of the viewport.
viewBox
with the midpoint X value of the viewport.
Align the
<min-y>+<height>
of the element's
viewBox
with the maximum Y value of the viewport.
<min-x>+<width>
of the element's
viewBox
with the maximum X value of the viewport.
Align the
<min-y>+<height>
of the element's
viewBox
with the maximum Y value of the viewport.
The meet or slice reference is optional and, if provided, must be one of the following keywords:
viewBox
is visible within the viewport
viewBox
is scaled up as much as possible, while still meeting the other criteria
viewBox
(i.e., the area into which the
viewBox
will draw will be smaller than the viewport).
viewBox
viewBox
is scaled down as much as possible, while still meeting the other criteria
viewBox
does not match the viewport, some of the
viewBox
will extend beyond the bounds of the viewport (i.e., the area into which the
viewBox
will draw is larger than the viewport).
You can use this attribute with the following SVG elements:
For
<feImage>
,
preserveAspectRatio
defines how the referenced image should fit in the rectangle define by the
<feImage>
元素。
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<image>
,
preserveAspectRatio
defines how the referenced image should fit in the rectangle define by the
<image>
元素。
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<marker>
,
preserveAspectRatio
indicates if a uniform scaling must be performed to fit the element viewport.
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<pattern>
,
preserveAspectRatio
indicates if a uniform scaling must be performed to fit the element viewport.
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<svg>
,
preserveAspectRatio
indicates if a uniform scaling must be performed to fit the element viewport.
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<symbol>
,
preserveAspectRatio
indicates if a uniform scaling must be performed to fit the element viewport.
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
For
<view>
,
preserveAspectRatio
indicates if a uniform scaling must be performed to fit the element viewport.
| 值 | <align> <meetOrSlice>? |
|---|---|
| 默认值 |
xMidYMid
meet
|
| Animatable | Yes |
最后修改: , 由 MDN 贡献者