Heim > Web-Frontend > CSS-Tutorial > Können CSS-Stile auf SVGs angewendet werden, die mit dem Tag „' eingebettet sind?

Können CSS-Stile auf SVGs angewendet werden, die mit dem Tag „' eingebettet sind?

Mary-Kate Olsen
Freigeben: 2024-12-24 22:16:15
Original
703 Leute haben es durchsucht

Can CSS Styles Be Applied to SVGs Embedded Using the `` Tag?

Anwenden von CSS-Stilen auf eingebettete SVGs

Beim Einfügen einer SVG-Datei direkt in ein Dokument mit der Funktion Wenn Sie ein Tag hinzufügen, ist es möglich, es über das Stylesheet des Dokuments zu formatieren. Es stellt sich jedoch die Frage: Kann ein ähnlicher Stil auf SVGs angewendet werden, die mit der Funktion eingebettet sind? Tag?

Kurze Antwort: Nein

CSS-Stile können keine Dokumentgrenzen überschreiten, einschließlich derjenigen zwischen dem Hauptdokument und dem eingebetteten SVG.

Alternative Lösungen

Da ein Wenn es sich um ein Stylesheet handelt, können Sie mithilfe von JavaScript ein Stylesheet in das SVG-Dokument einfügen. Hier ist ein Beispiel (vorausgesetzt, das wurde vollständig geladen):

var svgDoc = yourObjectElement.contentDocument;
var styleElement = svgDoc.createElementNS("http://www.w3.org/2000/svg", "style");
styleElement.textContent = "svg { fill: #fff }"; // style as desired
svgDoc.getElementById("where-to-insert").appendChild(styleElement);
Nach dem Login kopieren

Zusätzlich können Sie einen einfügen. Element zu einem externen Stylesheet:

var svgDoc = yourObjectElement.contentDocument;
var linkElm = svgDoc.createElementNS("http://www.w3.org/1999/xhtml", "link");
linkElm.setAttribute("href", "my-style.css");
linkElm.setAttribute("type", "text/css");
linkElm.setAttribute("rel", "stylesheet");
svgDoc.getElementById("where-to-insert").appendChild(linkElm);
Nach dem Login kopieren

Direkte Verlinkung

Sie können das Stylesheet auch direkt aus der SVG-Datei verlinken, ohne Skripting:

<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet href="my-style.css" type="text/css"?>
<svg xmlns="http://www.w3.org/2000/svg">
  ... rest of document here ...
</svg>
Nach dem Login kopieren

Zusätzliche Option: JQuery-SVG Plugin

Stand 2015 können Sie JS-Skripte und CSS-Stile mit dem jquery-svg-Plugin auf eingebettete SVGs anwenden.

Das obige ist der detaillierte Inhalt vonKönnen CSS-Stile auf SVGs angewendet werden, die mit dem Tag „' eingebettet sind?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage