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

11

我有一个HTML文件,将其分发给客户。它包含文档索引。我想为每个文档添加PDF或Word图标,但如果可以避免的话,我不想重复30次base64字符串。我该怎么做?JavaScript可以,但我的目标是简单和可移植性。

4个回答

16

尝试使用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。谢谢! - user736893
这是正确的想法。添加了一个兼容大多数浏览器的解决方案:https://dev59.com/uFoT5IYBdhLWcg3w8S61#44710590 - MartinTeeVarga

8
另一个使用CSS的答案提供了正确的想法,但它不兼容所有浏览器。CSS的content属性仅允许在伪元素::before::after中使用。带有内容属性类的img标签是空的。浏览器没有义务显示它。Chrome仍然显示它(不正确)。为了使其在所有浏览器上工作,请例如使用空span上的::before

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

你还可以直接将它附加到p::before

5
你可以使用CSS变量。
在页面的部分,命名并定义变量和使用它的类:
: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 类重复使用图片。 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的方法。

4
我是SingleFile的作者。SingleFile中SVG的目的是为图像提供大小而不改变CSS。因此,如果使用CSS设置图像的宽度和高度不是问题,那么可以确认您可以避免使用SVG。 - check_ca

1

创建一个脚本,将其插入到图像中。我故意将脚本代码内联,因为您正在发送单个HTML文件:

创建一个脚本,将其插入到图像中。由于您只发送了一个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>


1
应用程序是难点。我可以用jQuery做,但我不想要任何库或分离的文件。 - user736893
1
更新了我的答案 @Devil'sAdvocate。只是另一种方法。 - HaulinOats
2
这正是我期望的,感谢您的更新。但我更喜欢CSS解决方案。 - user736893
我从不同的来源听说在CSS中使用“content”是不好的,因为它会分离CSS、HTML和Javascript的用途。CSS应该仅用于表示,HTML用于内容,Javascript用于交互或DOM操作。老实说,在你具体的情况下,我认为这并不重要,而且我也不是专家,只是根据我所读到的编程社区的共识:http://www.karlgroves.com/2013/08/26/css-generated-content-is-not-content/ - HaulinOats
我尊重那个观点,但我从来不是粉丝。当然,我也会在盘子里混合食物。 - user736893

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接