如何在 HTML 文件中重复使用 base64 图像

How to reuse base64 image repeatedly in HTML file

我有一个 HTML 文件,可以移植分发给客户。它有一个文档索引。我想要每个文档的 PDF 或 Word 图标,但如果可以避免,我不想重复 base64 字符串 30 次。我应该怎么做? Javascript 没问题,但我的目标是简单性和可移植性。

创建脚本以将其插入到图像中。我故意将脚本代码内联,因为您发送的是单个 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>

尝试使用 CSS class

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>

使用 CSS 的另一个答案给出了正确的想法,但它并不与所有浏览器兼容。 CSS的content属性只允许出现在伪元素::before::after中。带有内容 属性 的 class 的 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

您可以使用 CSS 变量。

在页面的 <head> 部分,命名并定义变量和 class 以使用它:

:root {
    --img-123: url(data:null;base64,iVBORw………); /* your image data here */
}

.img-123 {
    background-blend-mode: normal;
    background-clip: content-box;
    background-position: 50% 50%;
    background-color: rgba(0,0,0,0);
    background-image:var(--img-123);
    background-size: 100% 100%;
    background-origin: content-box;
    background-repeat: no-repeat;
}

在页面的 <body> 部分,通过元素样式部分或 CSS classes 重复使用图像。 SVG 数据创建透明图像,通过它可以看到内容。

<img 
  class="img-123" 
  src="data:image/svg+xml,&lt;svg xmlns=&quot;http://www.w3.org/2000/svg&quot; width=&quot;16&quot; height=&quot;16&quot;&gt;&lt;rect fill-opacity=&quot;0&quot;/&gt;&lt;/svg&gt;"
>

我在开源 Firefox / Chrome 扩展程序 SingleFile 的输出中观察到了这种技术。可能有一些方法可以简化 CSS 并避免使用 SVG。