Vektorgrafiken zum Web hinzufügen

Vektorgrafiken sind in vielen Fällen sehr nützlich – sie haben kleine Dateigrößen und sind hoch skalierbar, sodass sie nicht verpixelt wirken, wenn man sie vergrößert oder auf eine große Größe ausdehnt. In diesem Artikel zeigen wir Ihnen, wie Sie eine auf Ihrer Webseite einfügen.

Voraussetzungen: Sie sollten die Grundlagen von HTML kennen und wissen, wie man ein Bild in Ihr Dokument einfügt.
Ziel: Lernen Sie, wie Sie ein SVG- (Vektor-) Bild auf einer Webseite einbetten.

Hinweis: Dieser Artikel soll Ihnen nicht beibringen, wie Sie SVG erstellen, sondern lediglich was es ist und wie Sie es zu Webseiten hinzufügen können.

Was sind Vektorgrafiken?

Im Web arbeiten Sie mit zwei Bildtypen — Rastergrafiken und Vektorgrafiken:

  • Rastergrafiken werden mithilfe eines Pixelrasters definiert — eine Rasterbilddatei enthält Informationen darüber, wo genau jedes Pixel platziert werden soll und welche Farbe es haben sollte. Beliebte Web-Rasterformate sind Bitmap (.bmp), PNG (.png), JPEG (.jpg) und GIF (.gif).
  • Vektorgrafiken werden mit Algorithmen definiert — eine Vektorgrafikdatei enthält Form- und Pfaddefinitionen, die der Computer verwenden kann, um zu bestimmen, wie das Bild beim Rendern auf dem Bildschirm aussehen soll. Das SVG-Format ermöglicht es uns, leistungsstarke Vektorgrafiken für den Einsatz im Web zu erstellen.

Um Ihnen einen Eindruck von dem Unterschied zwischen beiden zu geben, sehen wir uns ein Beispiel an. Sie finden dieses Beispiel live in unserem GitHub-Repo als vector-versus-raster.html — es zeigt zwei scheinbar identische Bilder nebeneinander, einen roten Stern mit einem schwarzen Schlagschatten. Der Unterschied besteht darin, dass das linke Bild eine PNG-Datei und das rechte eine SVG-Grafik ist.

Der Unterschied wird deutlich, wenn Sie in die Seite hineinzoomen — das PNG-Bild wird pixelig, weil es Informationen darüber enthält, wo jedes Pixel sein soll (und welche Farbe es hat). Wenn es vergrößert wird, wird jedes Pixel vergrößert, um mehrere Pixel auf dem Bildschirm zu füllen, sodass das Bild blockartig erscheint. Das Vektorgrafikbild hingegen bleibt schön und klar, da unabhängig von der Größe die Algorithmen verwendet werden, um die Formen im Bild zu berechnen, wobei die Werte skaliert werden, wenn es größer wird.

Zwei Sternbilder

Zwei Sternbilder vergrößert, eines scharf und das andere unscharf

Hinweis: Die obigen Bilder sind tatsächlich alle PNGs — mit dem linken Stern in jedem Fall als Darstellung einer Rastergrafik und dem rechten Stern als Darstellung einer Vektorgrafik. Gehen Sie erneut zur vector-versus-raster.html Demo für ein reales Beispiel!

Zudem sind Vektorgrafikdateien deutlich leichter als ihre Rasteräquivalente, da sie nur eine Handvoll Algorithmen enthalten müssen, anstatt Informationen über jedes Pixel im Bild einzeln.

Was ist SVG?

SVG ist eine XML-basierte Sprache zur Beschreibung von Vektorbildern. Es ist im Grunde genommen Markup, ähnlich wie HTML, nur dass es viele verschiedene Elemente zur Definition der Formen gibt, die Sie in Ihrem Bild erscheinen lassen möchten, und der Effekte, die Sie auf diese Formen anwenden möchten. SVG ist für die Auszeichnung von Grafiken und nicht von Inhalten gedacht. SVG definiert Elemente zur Erstellung grundlegender Formen wie <circle> und <rect>, sowie Elemente zur Erstellung komplexerer Formen wie <path> und <polygon>. Zu den fortgeschritteneren SVG-Funktionen gehören <feColorMatrix> (Farben mit einer Transformationsmatrix transformieren), <animate> (Teile Ihrer Vektorgrafik animieren) und <mask> (eine Maske über Ihr Bild legen).

Als einfaches Beispiel erstellt der folgende Code einen Kreis und ein Rechteck:

html
<svg
  version="1.1"
  baseProfile="full"
  width="300"
  height="200"
  xmlns="http://www.w3.org/2000/svg">
  <rect width="100%" height="100%" fill="black" />
  <circle cx="150" cy="100" r="90" fill="blue" />
</svg>

Dies erzeugt die folgende Ausgabe:

Aus dem obigen Beispiel könnten Sie den Eindruck gewinnen, dass SVG leicht von Hand zu codieren ist. Ja, Sie können einfaches SVG in einem Texteditor von Hand codieren, aber für ein komplexes Bild wird es sehr schnell schwierig. Zur Erstellung von SVG-Bildern verwenden die meisten Menschen einen Vektorgrafik-Editor wie Inkscape oder Illustrator. Diese Programme ermöglichen es Ihnen, eine Vielzahl von Illustrationen mit verschiedenen Grafikwerkzeugen zu erstellen und Foto-Nachbildungen zu erstellen (z. B. die Trace Bitmap-Funktion von Inkscape).

SVG hat einige zusätzliche Vorteile zusätzlich zu den bisher beschriebenen:

  • Text in Vektorgrafiken bleibt zugänglich (was auch Ihrem SEO zugutekommt).
  • SVGs eignen sich gut zum Styling/Scripting, da jede Komponente des Bildes ein Element ist, das mittels CSS gestylt oder mittels JavaScript gescriptet werden kann.

Warum also sollte jemand Rastergrafiken gegenüber SVG verwenden wollen? Nun, SVG hat auch einige Nachteile:

  • SVG kann sehr schnell kompliziert werden, was bedeutet, dass die Dateigrößen zunehmen können; komplexe SVGs können auch erhebliche Verarbeitungszeiten im Browser benötigen.
  • SVG kann schwerer zu erstellen sein als Rasterbilder, je nachdem, welche Art von Bild Sie erstellen möchten.

Rastergrafiken sind möglicherweise besser für komplexe Präzisionsbilder wie Fotos geeignet, aus den oben beschriebenen Gründen.

Hinweis: Speichern Sie Ihre Dateien in Inkscape als Plain SVG, um Speicherplatz zu sparen. Bitte beachten Sie auch diesen Artikel, der beschreibt, wie man SVGs für das Web vorbereitet.

SVG zu Ihren Seiten hinzufügen

In diesem Abschnitt erläutern wir die verschiedenen Möglichkeiten, wie Sie SVG-Vektorgrafiken zu Ihren Webseiten hinzufügen können.

Der schnelle Weg: img-Element

Um eine SVG über ein <img>-Element einzubetten, müssen Sie es nur wie erwartet im src-Attribut referenzieren. Sie benötigen ein height- oder ein width-Attribut (oder beides, wenn Ihr SVG kein internes Seitenverhältnis hat). Wenn Sie es noch nicht getan haben, lesen Sie bitte Bilder in HTML.

html
<img
  src="equilateral.svg"
  alt="triangle with all three sides equal"
  height="87"
  width="100" />

Vorteile

  • Schnelle, vertraute Bildsyntax mit integriertem Textequivalent im alt-Attribut.
  • Sie können das Bild leicht in einen Hyperlink verwandeln, indem Sie das <img> in ein <a>-Element einschließen.
  • Die SVG-Datei kann vom Browser zwischengespeichert werden, was zu schnelleren Ladezeiten für alle Seiten führt, die das Bild in Zukunft verwenden.

Nachteile

  • Sie können das Bild nicht mit JavaScript manipulieren.
  • Wenn Sie den SVG-Inhalt mit CSS steuern möchten, müssen Sie Inline-CSS-Stile in Ihrem SVG-Code einfügen. (Externe Stylesheets, die aus der SVG-Datei aufgerufen werden, haben keine Wirkung.)
  • Sie können das Bild nicht mit CSS-Pseudoklassen (wie :focus) erneut gestalten.

Fehlerbehebung und plattformübergreifende Unterstützung

Für Browser, die SVG nicht unterstützen (IE 8 und darunter, Android 2.3 und darunter), könnten Sie ein PNG oder JPG aus Ihrem src-Attribut referenzieren und ein srcset-Attribut verwenden (das nur von neueren Browsern anerkannt wird), um auf das SVG zu verweisen. In diesem Fall laden nur unterstützende Browser das SVG – ältere Browser laden stattdessen das PNG:

html
<img
  src="equilateral.png"
  alt="triangle with equal sides"
  srcset="equilateral.svg" />

Sie können SVGs auch als CSS-Hintergrundbilder verwenden, wie unten gezeigt. Im folgenden Code verwenden ältere Browser das ihnen bekannte PNG, während neuere Browser das SVG laden:

css
background: url("fallback.png") no-repeat center;
background-image: url("image.svg");
background-size: contain;

Wie bei der oben beschriebenen <img>-Methode bedeutet das Einfügen von SVGs mithilfe von CSS-Hintergrundbildern, dass das SVG nicht mit JavaScript manipuliert werden kann und den gleichen CSS-Einschränkungen unterliegt.

Wenn Ihre SVGs überhaupt nicht angezeigt werden, könnte es daran liegen, dass Ihr Server nicht richtig eingerichtet ist. Wenn das das Problem ist, wird Ihnen dieser Artikel in die richtige Richtung weisen.

Wie man SVG-Code in Ihr HTML einfügt

Sie können die SVG-Datei auch in einem Texteditor öffnen, den SVG-Code kopieren und in Ihr HTML-Dokument einfügen – dies wird manchmal als SVG inline setzen oder SVG einbetten bezeichnet. Stellen Sie sicher, dass Ihr SVG-Code-Schnipsel mit einem <svg>-Starttag beginnt und mit einem </svg>-Endtag endet. Hier ist ein sehr einfaches Beispiel dafür, was Sie vielleicht in Ihr Dokument einfügen würden:

html
<svg width="300" height="200">
  <rect width="100%" height="100%" fill="green" />
</svg>

Vorteile

  • Das Einfügen von SVG in Ihr Dokument spart eine HTTP-Anfrage und kann daher Ihre Ladezeit etwas reduzieren.
  • Sie können class- oder id-Attribute auf SVG-Elemente anwenden und diese mit CSS stylen, entweder innerhalb des SVGs oder wo auch immer Sie die CSS-Stilregeln für Ihr HTML-Dokument platzieren. Tatsächlich können Sie jedes SVG-Präsentationsattribut als CSS-Eigenschaft verwenden.
  • Das Einbetten von SVG ist der einzige Ansatz, der es Ihnen ermöglicht, CSS-Interaktionen (wie :focus) und CSS-Animationen auf Ihr SVG-Bild anzuwenden (sogar in Ihrem regulären Stylesheet).
  • Sie können SVG-Markup in einen Hyperlink verwandeln, indem Sie es in ein <a>-Element einwickeln.

Nachteile

  • Diese Methode eignet sich nur, wenn Sie das SVG an nur einer Stelle verwenden. Duplikation macht die Wartung ressourcenintensiv.
  • Zusätzlicher SVG-Code erhöht die Größe Ihrer HTML-Datei.
  • Der Browser kann eingebettete SVGs nicht wie reguläre Bildressourcen zwischenspeichern, sodass Seiten, die das Bild enthalten, nach dem Laden der ersten Seite mit dem Bild nicht schneller geladen werden.
  • Sie können Fallback-Bilder in einem <foreignObject>-Element einfügen, aber Browser, die SVG unterstützen, laden trotzdem alle Fallback-Bilder herunter. Sie müssen abwägen, ob der zusätzliche Aufwand wirklich lohnenswert ist, nur um obsoleszente Browser zu unterstützen.

Wie man ein SVG mit einem iframe einbettet

Sie können SVG-Bilder im Browser genauso öffnen wie Webseiten. Das Einbetten eines SVG-Dokuments mit einem <iframe> erfolgt genauso, wie wir es in Von <object> zu <iframe> — andere Einbetttechnologien gelernt haben.

Hier ist eine schnelle Übersicht:

html
<iframe src="triangle.svg" width="500" height="500" sandbox>
  <img src="triangle.png" alt="Triangle with three unequal sides" />
</iframe>

Das ist definitiv nicht die beste Methode zur Auswahl:

Nachteile

  • iframes haben zwar einen Fallback-Mechanismus, wie Sie sehen können, aber Browser zeigen den Fallback nur an, wenn ihnen die Unterstützung für iframes insgesamt fehlt.
  • Darüber hinaus können Sie, sofern das SVG und Ihre aktuelle Webseite nicht denselben Ursprung haben, nicht mit JavaScript auf Ihrer Hauptwebseite das SVG manipulieren.

Aktives Lernen: Spielen mit SVG

In diesem aktiven Lernabschnitt möchten wir, dass Sie ein wenig mit SVG spielen, einfach aus Spaß. Im Input-Abschnitt unten sehen Sie, dass wir Ihnen bereits einige Beispiele zur Verfügung gestellt haben, um Sie zu starten. Sie können auch zum SVG-Element-Referenz gehen, mehr Details über andere Tools herausfinden, die Sie in SVG verwenden können, und diese auch ausprobieren. Dieser Abschnitt dreht sich darum, Ihre Recherchefähigkeiten zu üben und ein wenig Spaß zu haben.

Wenn Sie hängen bleiben und Ihren Code nicht zum Laufen bringen, können Sie ihn immer mit dem Zurücksetzen Button zurücksetzen.

Zusammenfassung

Dieser Artikel hat Ihnen einen kurzen Überblick gegeben über das, was Vektorgrafiken und SVG sind, warum sie nützlich sind und wie man SVG in Ihre Webseiten einfügt. Es war nie beabsichtigt, ein vollständiger Leitfaden zum Erlernen von SVG zu sein, sondern nur ein Hinweis, damit Sie wissen, was SVG ist, wenn Sie es auf Ihren Reisen durchs Web begegnen. Machen Sie sich also keine Sorgen, wenn Sie sich noch nicht wie ein SVG-Experte fühlen. Wir haben einige Links unten eingefügt, die Ihnen helfen könnten, wenn Sie mehr darüber erfahren möchten, wie es funktioniert.

Im letzten Artikel dieses Moduls werden wir uns detaillierter mit reaktionsfähigen Bildern beschäftigen und die Werkzeuge untersuchen, die HTML bietet, um Ihre Bilder besser über verschiedene Geräte hinweg arbeiten zu lassen.

Siehe auch