2017-08-12 3 views
0

von diesem Artikel inspiriert How SVG Fragment Identifiers Work, ich versuche SVG Sprite zu erstellen, und mit der Verwendung von viewBox Platz Symbole in Sheet als Hintergrund gewählt ...SVG Sprite nicht funktionieren - Symbole angezeigt auf Stapel

Leider habe ich angetroffen ein echtes Problem ... Ich kann nicht wählen, richtige Symbol zur Anzeige, weil alle Symbole auf Stapel gelegt werden und einander abdecken ...

Ich habe versucht, Koordinaten x & y zu verwenden, um Icons Gruppe zu trennen, aber Es gibt kein Ergebnis im Webbrowser (sie befinden sich immer noch auf dem Stapel), obwohl wenn ich die Sprite-Datei in Sketch/AI platzierte, sind sie getrennt.

<view id="icon-facebook" viewBox="0 0 24 24" /> 
<view id="icon-instagram" viewBox="0 24 24 24" /> 

<g id="icon-instagram" fill="red"> 
    <path fill-rule="nonzero" d="M17.2808471,0 L6.58644706,0 C2.95468235,0 0,2.95482353 0,6.58658824 L0,17.2809882 C0,20.9128941 2.95468235,23.8675765 6.58644706,23.8675765 L17.2808471,23.8675765 C20.9128941,23.8675765 23.8675765,20.9127529 23.8675765,17.2809882 L23.8675765,6.58658824 C23.8677176,2.95482353 20.9128941,0 17.2808471,0 Z M21.7500706,17.2809882 C21.7500706,19.7452235 19.7452235,21.7499294 17.2809882,21.7499294 L6.58644706,21.7499294 C4.12235294,21.7500706 2.11764706,19.7452235 2.11764706,17.2809882 L2.11764706,6.58658824 C2.11764706,4.12249412 4.12235294,2.11764706 6.58644706,2.11764706 L17.2808471,2.11764706 C19.7450824,2.11764706 21.7499294,4.12249412 21.7499294,6.58658824 L21.7499294,17.2809882 L21.7500706,17.2809882 Z"/> 
    <path fill-rule="nonzero" d="M11.9337882 5.784C8.54258824 5.784 5.78371765 8.54287059 5.78371765 11.9340706 5.78371765 15.3251294 8.54258824 18.0838588 11.9337882 18.0838588 15.3249882 18.0838588 18.0838588 15.3251294 18.0838588 11.9340706 18.0838588 8.54287059 15.3249882 5.784 11.9337882 5.784zM11.9337882 15.9660706C9.7104 15.9660706 7.90136471 14.1573176 7.90136471 11.9339294 7.90136471 9.7104 9.71025882 7.90150588 11.9337882 7.90150588 14.1573176 7.90150588 15.9662118 9.7104 15.9662118 11.9339294 15.9662118 14.1573176 14.1571765 15.9660706 11.9337882 15.9660706zM18.3417882 3.98837647C17.9337882 3.98837647 17.5329882 4.15355294 17.2448471 4.44296471 16.9552941 4.73096471 16.7888471 5.13190588 16.7888471 5.54131765 16.7888471 5.94945882 16.9554353 6.35025882 17.2448471 6.63967059 17.5328471 6.92767059 17.9337882 7.09425882 18.3417882 7.09425882 18.7512 7.09425882 19.1507294 6.92767059 19.4401412 6.63967059 19.7295529 6.35025882 19.8947294 5.94931765 19.8947294 5.54131765 19.8947294 5.13190588 19.7295529 4.73096471 19.4401412 4.44296471 19.1521412 4.15355294 18.7512 3.98837647 18.3417882 3.98837647z"/> 
</g> 

<g id="icon-facebook" fill="pink" > 
    <path d="M2.93630055,4.93539414 L2.93630055,8.17223941 L0.564884222,8.17223941 L0.564884222,12.1302664 L2.93630055,12.1302664 L2.93630055,23.8921306 L7.80769311,23.8921306 L7.80769311,12.1305943 L11.0766237,12.1305943 C11.0766237,12.1305943 11.3827734,10.2327507 11.5311748,8.15764524 L7.82611347,8.15764524 L7.82611347,5.45138285 C7.82611347,5.04690017 8.35724295,4.50281631 8.88219587,4.50281631 L11.5363128,4.50281631 L11.5363128,0.382285714 L7.92761676,0.382285714 C2.81588497,0.382012415 2.93630055,4.34397487 2.93630055,4.93539414 Z"/> 
</g> 

JSfiddle with the problem

+1

Es wurde um Hilfe zu rufen;) – user3406262

Antwort

1

Es gibt ein paar Dinge falsch hier.

Offensichtlich ist einer von ihnen, dass Ihre Symbole nicht an der richtigen Stelle sind.

Die zweite ist die Ansicht Ids. IDs müssen in der Datei eindeutig sein, aber Sie haben zwei mit dem Namen "icon-facebook" usw. Deshalb verwendet diese Lernprogrammseite das Suffix -view für die View-IDs. Z.B. icon-clock-view.

Für das erste Problem würden Sie normalerweise Ihre Datei so entwerfen, dass die Symbole in einem Raster angeordnet wurden. Ich bin mir nicht sicher, wie Sie Ihre Datei erstellt haben und warum sie nicht so funktioniert. Um dies zu beheben, können Sie die Datei entweder in einem Vektoreditor bearbeiten oder Sie können manuell ein transform zu den betroffenen Symbolen hinzufügen, um sie an den richtigen Ort zu verschieben.

Da Ihre Ansichtsdefinition besagt, dass das Instagram-Symbol auf (0, 24) steht (das sind die ersten beiden Werte in viewBox), sollten wir dieses Symbol auf diese Position verschieben.

<g id="icon-instagram" fill="red"> 
    <g transform="translate(0,24)"> 
    <path ... /> 

beachten, dass das Symbol Instagram von zwei Pfaden besteht. Also anstatt die transform beiden Pfaden hinzuzufügen, habe ich sie in ein Gruppen-Tag eingeschlossen und die Transformation darauf angewendet. Hier

ist die modifizierte SVG:

<?xml version="1.0" encoding="utf-8"?> 
 
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> 
 
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 24 48" enable-background="new 0 0 24 48" xml:space="preserve"> 
 

 
    <view id="icon-facebook-view" viewBox="0 0 24 24" /> 
 
    <view id="icon-instagram-view" viewBox="0 24 24 24" /> 
 

 
    <g id="icon-instagram" fill="red"> 
 
     <g transform="translate(0,24)"> 
 
     <path fill-rule="nonzero" d="M17.2808471,0 L6.58644706,0 C2.95468235,0 0,2.95482353 0,6.58658824 L0,17.2809882 C0,20.9128941 2.95468235,23.8675765 6.58644706,23.8675765 L17.2808471,23.8675765 C20.9128941,23.8675765 23.8675765,20.9127529 23.8675765,17.2809882 L23.8675765,6.58658824 C23.8677176,2.95482353 20.9128941,0 17.2808471,0 Z M21.7500706,17.2809882 C21.7500706,19.7452235 19.7452235,21.7499294 17.2809882,21.7499294 L6.58644706,21.7499294 C4.12235294,21.7500706 2.11764706,19.7452235 2.11764706,17.2809882 L2.11764706,6.58658824 C2.11764706,4.12249412 4.12235294,2.11764706 6.58644706,2.11764706 L17.2808471,2.11764706 C19.7450824,2.11764706 21.7499294,4.12249412 21.7499294,6.58658824 L21.7499294,17.2809882 L21.7500706,17.2809882 Z"/> 
 
     <path fill-rule="nonzero" d="M11.9337882 5.784C8.54258824 5.784 5.78371765 8.54287059 5.78371765 11.9340706 5.78371765 15.3251294 8.54258824 18.0838588 11.9337882 18.0838588 15.3249882 18.0838588 18.0838588 15.3251294 18.0838588 11.9340706 18.0838588 8.54287059 15.3249882 5.784 11.9337882 5.784zM11.9337882 15.9660706C9.7104 15.9660706 7.90136471 14.1573176 7.90136471 11.9339294 7.90136471 9.7104 9.71025882 7.90150588 11.9337882 7.90150588 14.1573176 7.90150588 15.9662118 9.7104 15.9662118 11.9339294 15.9662118 14.1573176 14.1571765 15.9660706 11.9337882 15.9660706zM18.3417882 3.98837647C17.9337882 3.98837647 17.5329882 4.15355294 17.2448471 4.44296471 16.9552941 4.73096471 16.7888471 5.13190588 16.7888471 5.54131765 16.7888471 5.94945882 16.9554353 6.35025882 17.2448471 6.63967059 17.5328471 6.92767059 17.9337882 7.09425882 18.3417882 7.09425882 18.7512 7.09425882 19.1507294 6.92767059 19.4401412 6.63967059 19.7295529 6.35025882 19.8947294 5.94931765 19.8947294 5.54131765 19.8947294 5.13190588 19.7295529 4.73096471 19.4401412 4.44296471 19.1521412 4.15355294 18.7512 3.98837647 18.3417882 3.98837647z"/> 
 
     </g> 
 
    </g> 
 

 
    <g id="icon-facebook" fill="pink" > 
 
     <path d="M2.93630055,4.93539414 L2.93630055,8.17223941 L0.564884222,8.17223941 L0.564884222,12.1302664 L2.93630055,12.1302664 L2.93630055,23.8921306 L7.80769311,23.8921306 L7.80769311,12.1305943 L11.0766237,12.1305943 C11.0766237,12.1305943 11.3827734,10.2327507 11.5311748,8.15764524 L7.82611347,8.15764524 L7.82611347,5.45138285 C7.82611347,5.04690017 8.35724295,4.50281631 8.88219587,4.50281631 L11.5363128,4.50281631 L11.5363128,0.382285714 L7.92761676,0.382285714 C2.81588497,0.382012415 2.93630055,4.34397487 2.93630055,4.93539414 Z"/> 
 
    </g> 
 
</svg>

Und Sie würden die Symbole wie diese Referenz:

<img src="sprite.svg#icon-facebook-view"> 
<img src="sprite.svg#icon-instagram-view"> 
+0

Vielen Dank für deine Antwort :)! Es funktioniert gut, aber in der Zwischenzeit habe ich daran gearbeitet, Symbole auf dem Stapel anzuzeigen, die das Ziel verwenden. Es funktioniert gut in Chrome & Firefox, aber SVG erscheint nicht in Safari ... Könnte ich auf meine Antwort schauen und versuchen, mir bei der Lösung zu helfen? – user3406262