2015-02-27 7 views
6

Wie kann ich ein SVG-Daten-URI in CSS einbetten, indem der Präprozessor Stylus verwendet wird, ohne dass das SVG Base64-codiert ist?Stylus Inline SVG-Daten-URI ohne base64-Codierung

So:

background: url('data:image/svg+xml;utf8,<svg>[...]</svg>'); 

statt dessen:

background: url('[...]'); 

Normaly habe ich verwendet stylus.url() Bilder einbetten, aber es wird auch Base64 kodieren SVGs.

Ich möchte Daten anstelle von externen Dateien verwenden, um Dateianfragen zu speichern. Und ich habe festgestellt, dass Base64-Codierung SVGs Bytes tatsächlich hinzufügt, anstatt die Größe zu reduzieren.

Ich kann keine Methode zum Einbetten der SVG wie sie ist finden.

+0

Sie können keine externat SVG-Datei tun und es in CSS nennen? Wie Hintergrund: URL (youshape.svg); – Mat

+0

Auch Hintergrundbilder (sogar SVG) sind ** nicht ** "Inline-Bilder". –

+0

@Paulie_D Ich bin an SASS und Compass gewöhnt, wo die Methode wörtlich "inline-image()" genannt wird, was mich verwirrt hat. Wie würdest du es nennen? "einbetten"? – pstenstrm

Antwort

4

Da ich keinen etablierten Weg finden konnte, musste ich es selbst lösen. Ich schrieb ein einfaches Knotenmodul, das stylus.url() umschließt, aber ersetzt, wie SVGs inline sind.

Link zu dem Modul: https://www.npmjs.com/package/stylus-inline-svg

Mit Ausnahme einiger Kontrollen im Grunde tut es dies:

found = stylus.utils.lookup(url.string, options.paths); 

if(!found) return literal; 

buf = fs.readFileSync(found); 

buf = String(buf) 
    .replace(/<\?xml(.+?)\?>/, '') 
    .replace(/^\s+|\s+$/g, '') 
    .replace(/(\r\n|\n|\r)/gm, ''); 

return new stylus.nodes.Literal("url('data:image/svg+xml;utf8," + buf + "')"); 
0

Verwenden CSS Wörtliche:

@css { 
    .svg { 
     background: url('[...]'); 
    } 
} 

Kompilieren zu:

.svg { 
     background: url('[...]'); 
    }