Home > Web Front-end > CSS Tutorial > How Do I Scale Inline SVGs to Fit Their Parent Containers While Maintaining Aspect Ratio?

How Do I Scale Inline SVGs to Fit Their Parent Containers While Maintaining Aspect Ratio?

Linda Hamilton
Release: 2024-12-11 14:04:11
Original
670 people have browsed it

How Do I Scale Inline SVGs to Fit Their Parent Containers While Maintaining Aspect Ratio?

Scaling Inline SVGs to Fit Parent Containers

Inline SVGs offer the flexibility of adding vector graphics directly to HTML documents. However, scaling them to match the size of the parent container while maintaining aspect ratio can present a challenge. Here's how to achieve this using the viewBox attribute:

To make an inline SVG scale, we employ the viewBox attribute on the SVG element. This attribute defines the bounding box of the image within its own coordinate system. Subsequently, we specify the desired width and height using the width and height attributes, which are relative to the containing page.

Consider the following example, which displays a 10px by 20px triangle:

<svg viewBox="0 0 20 10">
    <polygon fill="red" stroke-width="0"
             points="0,10 20,10 10,0" />
</svg>
Copy after login

This SVG will render as a 10px by 20px triangle within the given container, regardless of its size. The viewBox attribute (0 0 20 10) defines the coordinate system of the image, with (0,0) being the top-left corner and (20,10) being the bottom-right corner. By specifying the width and height attributes (not shown in the example), we scale the image to the desired size relative to the container while maintaining its aspect ratio.

The above is the detailed content of How Do I Scale Inline SVGs to Fit Their Parent Containers While Maintaining Aspect Ratio?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template