Heim >Web-Frontend >CSS-Tutorial >Wie erstelle ich einen responsiven Clip-Pfad mit Inline SVG?

Wie erstelle ich einen responsiven Clip-Pfad mit Inline SVG?

Barbara Streisand
Barbara StreisandOriginal
2024-11-03 05:20:30841Durchsuche

How to Create a Responsive Clip-Path with Inline SVG?

Responsiver Clip-Pfad mit Inline-SVG

Wenn Sie SVG verwenden, um einen Clip-Pfad für ein Element mit Hintergrund zu erstellen, ist es wichtig, Folgendes zu tun Verstehen Sie, wie ViewBox und PreserveAspectRatio funktionieren. Das Attribut „viewBox“ definiert die Abmessungen des SVG-Inhalts, während „preserveAspectRatio“ bestimmt, wie dieser Inhalt skaliert und in das Element eingepasst wird.

In Ihrem Code-Snippet wenden Sie den Clip-Pfad auf ein Header-Element mit a an Höhe von 100 Pixel:

<code class="css">#block-header {
  min-height: 100px;
  clip-path: url(#myClip);
}</code>

Ihr SVG hat jedoch eine ViewBox von „0 0 4000 1696“, was bedeutet, dass der Clip-Pfad mit einer Breite von 4000 Pixel angewendet wird. Dies ist wahrscheinlich viel größer als die tatsächliche Breite des Header-Elements, weshalb Sie nicht den gewünschten Effekt sehen.

Um einen responsiven Clip-Pfad zu erstellen, müssen Sie die ViewBox der SVG so definieren, dass sie mit der übereinstimmt Abmessungen des Elements, auf das es angewendet wird. Sie können auch das Attribut „clipPathUnits“ verwenden, um anzugeben, dass der Pfad in Einheiten relativ zum Begrenzungsrahmen des Elements definiert wird:

<code class="css">#block-header {
  min-height: 100px;
  clip-path: url(#myClip);
}

#myClip {
  clipPathUnits: objectBoundingBox;
}</code>

Mit diesen Änderungen wird die SVG-Datei so skaliert, dass sie zu den Abmessungen des Headers passt Element, und der Clip-Pfad wird korrekt angewendet.

Das obige ist der detaillierte Inhalt vonWie erstelle ich einen responsiven Clip-Pfad mit Inline SVG?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn