Warum kopieren Sie nicht den SVG-Knoten/Baum und nehmen Sie dann die Stile als defiend pro Tag (Sie benötigen den Originalbaum, da die Kopie ohne Stile sein kann, falls das Element Teil eines längeren Baumes ist). Dadurch wird sichergestellt, dass Sie nur die relevanten Stile kopieren, die in der CSS-Datei festgelegt wurden. Der Exporttyp Blob leicht einstellen, das Paket könnte
var ContainerElements = ["svg","g"];
var RelevantStyles = {"rect":["fill","stroke","stroke-width"],"path":["fill","stroke","stroke-width"],"circle":["fill","stroke","stroke-width"],"line":["stroke","stroke-width"],"text":["fill","font-size","text-anchor"],"polygon":["stroke","fill"]};
function read_Element(ParentNode, OrigData){
var Children = ParentNode.childNodes;
var OrigChildDat = OrigData.childNodes;
for (var cd = 0; cd < Children.length; cd++){
var Child = Children[cd];
var TagName = Child.tagName;
if (ContainerElements.indexOf(TagName) != -1){
read_Element(Child, OrigChildDat[cd])
} else if (TagName in RelevantStyles){
var StyleDef = window.getComputedStyle(OrigChildDat[cd]);
var StyleString = "";
for (var st = 0; st < RelevantStyles[TagName].length; st++){
StyleString += RelevantStyles[TagName][st] + ":" + StyleDef.getPropertyValue(RelevantStyles[TagName][st]) + "; ";
}
Child.setAttribute("style",StyleString);
}
}
}
function export_StyledSVG(SVGElem){
var oDOM = SVGElem.cloneNode(true)
read_Element(oDOM, SVGElem)
var data = new XMLSerializer().serializeToString(oDOM);
var svg = new Blob([data], { type: "image/svg+xml;charset=utf-8" });
var url = URL.createObjectURL(svg);
var link = document.createElement("a");
link.setAttribute("target","_blank");
var Text = document.createTextNode("Export");
link.appendChild(Text);
link.href=url;
document.body.appendChild(link);
}
Diese Traversierungsfunktion scheint nur eine Schicht tief zu gehen, was mir keinen Nutzen brachte. Mit jQuery werden in der folgenden Zeile alle Elemente durch 'explicitSetStyle' '$ (' # svg ') zur Ausführung gebracht. Find (" * ");' – Craig