2016-06-24 3 views
3

Ich habe eine HTML-Datei, die für die Verteilung an Clients portierbar sein wird. Es hat einen Index von Dokumenten. Ich möchte für jedes Dokument ein PDF- oder Word-Symbol, aber ich möchte die base64-Zeichenfolge 30 Mal nicht wiederholen, wenn ich es vermeiden kann. Wie soll ich das machen? Javascript ist in Ordnung, aber meine Ziele sind Einfachheit und Portabilität.Wie base64 Bild wiederholt in HTML-Datei wiederverwenden

Antwort

9

Versuchen CSS-Klasse

img.word-icon { 
 
    content: url(); 
 
    width: 32px; 
 
    height: 32px; 
 
}
<html> 
 
    <body> 
 
    <img class="word-icon">foo 
 
    <img class="word-icon">bar 
 
    <img class="word-icon"> 
 
    </body> 
 
</html>

+2

Oh, jetzt ist das brilliant. Ich hatte nicht an CSS gedacht. Vielen Dank! –

+0

Das ist die richtige Idee. Eine Lösung hinzugefügt, die mit den meisten Browsern kompatibel ist: https://stackoverflow.com/a/44710590/1667977 – sm4

1

erstellen Sie ein Skript, um es in die Bilder einzufügen. Ich legte den Script-Code inline absichtlich, da Sie eine einzelne HTML-Datei sind zu senden:

<img alt="pdf"/> 
 
<img alt="pdf"/> 
 
<img alt="pdf"/> 
 
<img alt="pdf"/> 
 
<img alt="pdf"/> 
 
<img alt="pdf"/> 
 
<script> 
 
    var images = document.getElementsByTagName('img'); 
 
for (var i = 0; i < images.length; i++){ 
 
    images[i].src = ""; 
 
} 
 
</script>

+0

Die Anwendung ist die Schwierigkeit. Ich könnte es in JQuery tun, aber ich möchte keine Bibliotheken oder separate Dateien. –

+1

Aktualisiert meine Antwort @ Devil'sAdvocate. Nur ein anderer Ansatz. – Brett84c

+2

Das habe ich erwartet, danke für das Update. Aber ich bevorzuge die CSS-Lösung. –

2

die andere Antwort mit Die Verwendung von CSS bietet die richtige Idee, ist jedoch nicht mit allen Browsern kompatibel. Die Eigenschaft content des CSS ist nur in den Pseudoelementen ::before und ::after zulässig. Das img-Tag mit einer Klasse mit einer Inhaltseigenschaft ist leer. Die Browser sind nicht verpflichtet, sie anzuzeigen. Chrome zeigt es trotzdem (falsch) an.

Um diese Arbeit für alle Browser zu machen, verwenden Sie zum Beispiel die ::before auf einem leeren Feld:

span.word-icon::before { 
 
    content: url(); 
 
}
<html> 
 
    <body> 
 
    <p><span class="word-icon"></span>Paragraph with icon.</p> 
 
    </body> 
 
</html>

Sie können es auch direkt an p::before befestigen.