2016-06-24 1 views
3

У меня есть HTML-файл, который будет переносимым для распространения среди клиентов. У него есть индекс документов. Мне нужен значок PDF или Word для каждого документа, но я не хочу повторять строку base64 30 раз, если я могу избежать этого. Как мне это сделать? Javascript в порядке, но мои цели - простота и переносимость.Как повторно использовать изображение base64 в файле HTML

ответ

9

Попробуйте использовать класс CSS

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

О, теперь это великолепно. Я не думал о CSS. Благодаря! –

+0

Это правильная идея. Добавлено решение, совместимое с большинством браузеров: https://stackoverflow.com/a/44710590/1667977 – sm4

1

создать сценарий, чтобы вставить его в изображения. Я намеренно поставил код сценария в линию, так как вы отправляете один HTML файл:

<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

Приложение - это сложность. Я мог бы сделать это в JQuery, но я не хочу никаких библиотек или отдельных файлов. –

+1

Обновлен мой ответ @ Devil'sAdvocate. Еще один подход. – Brett84c

+2

Это то, чего я ожидал, спасибо за обновление. Но я предпочитаю решение CSS. –

2

Другой ответ использование CSS дает правильную идею, но не совместимо со всеми браузерами. Свойство content CSS допускается только в псевдоэлементах ::before и ::after. Тег img с классом с содержимым пуст. Браузеры не обязаны отображать его. Chrome отображает его, тем не менее (неправильно).

Чтобы сделать эту работу для всех браузеров, используйте, например, ::before на пустой промежуток:

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

Вы также можете прикрепить его непосредственно к p::before.